

## SDK-86 MCS-86<sup>™</sup>SYSTEM DESIGN KIT USER'S GUIDE

Order Number: 9800698-02 Rev. B

# SDK-86 MCS-86<sup>™</sup> SYSTEM DESIGN KIT USER'S GUIDE

Order Number: 9800698-02 Rev. B

Additional copies of this manual or other Intel literature may be obtained from:

Literature Department Intel Corporation 3065 Bowers Avenue Santa Clara, CA 95051

The information in this document is subject to change without notice.

Intel Corporation makes no warranty of any kind with regard to this material, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. Intel Corporation assumes no responsibility for any errors that may appear in this document. Intel Corporation makes no commitment to update nor to keep current the information contained in this document.

Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in an Intel product. No other circuit patent licenses are implied.

Intel software products are copyrighted by and shall remain the property of Intel Corporation. Use, duplication or disclosure is subject to restrictions stated in Intel's software license, or as defined in ASPR 7-104.9(a) (9).

No part of this document may be copied or reproduced in any form or by any means without prior written consent of Intel Corporation.

Intel Corporation makes no warranty for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

Intel retains the right to make changes to these specifications at any time, without notice.

Contact your local sales office to obtain the latest specifications before placing your order.

The following are trademarks of Intel Corporation and its affiliates and may be used only to identify Intel products:

| AEDIT              | iLBX                   | iOSP            | MULTIBUS      |
|--------------------|------------------------|-----------------|---------------|
| BITBUS             | im                     | iPDS            | MULTICHANNE   |
| BXP                | iMMX                   | iRMX            | MULTIMODULE   |
| COMMputer          | Insite                 | iSBC            | Plug-A-Bubble |
| CREDIT             | Intel                  | iSBX            | PROMPT        |
| i                  | IntelBOS               | iSDM            | Promware      |
| iATC               | Intelevision           | iSXM            | Ripplemode    |
| I <sup>2</sup> ICE | inteligent Identifier  | Library Manager | RMX/80        |
| ICE                | inteligent Programming | MCS             | RUPI          |
| iCS                | Intellec               | Megachassis     | System 2000   |
| iDBP               | Intellink              | MICROMAINFRAME  | UPI           |
| :DIG               |                        |                 |               |

MDS is an ordering code only and is not used as a product name or trademark. MDS® is a registered trademark of Mohawk Data Sciences Corporation.

\*MULTIBUS is a patented Intel bus.

Copyright © 1983, Intel Corporation



## SERVICE ASSISTANCE

If, following assembly, you cannot get your kit to operate satisfactorily, the Intel Technical Support Center "Service Hotline" is available for assistance. This service is provided during the hours of 7:30AM to 4:30PM (Mountain Time), Monday through Friday. The toll-free Hotline telephone number is:

(800) 528-0595 when dialing from outside the state of Arizona

When dialing from within the state of Arizona, dial (602) 869-4600

The Hotline is intended expressly to help you get your kit running and is *not* intended to assist you in circuit designs or applications. Telephone assistance is limited to *one* call per problem. If a problem cannot be remedied over the telephone, you may, at your discretion, return your assembled kit to Intel for repair. To return your kit, a Return Authorization Number *must be obtained* from the Technical Support Center prior to sending in your kit. Also, either a purchase order number for the repairs must be furnished to the center or a money order (no personal checks please) must be included with the kit being returned. Repairs resulting from defective components supplied with your kit will be done at no charge, and all prepayments will be refunded. Repairs necessitated as a result of customer error, damage or misuse will be billed at a fixed, flat-rate charge which will be quoted by the Technical Support Center.

#### **NOTE**

The Technical Support Center will not repair an SDK-86 Kit that has been modified and, when circuitry has been added to the user design area, may request that the circuitry be disconnected prior to submitting the kit to the center for repair.

## **PREFACE**



This is the user's guide for the MCS-86 System Design Kit (SDK-86). Included within this guide are descriptions of the two ROM-resident monitor programs that allow you to communicate with your kit, a functional description of the SDK-86 itself, interfacing information and design examples for expanding your kit's capabilities. Additional information is available in the following Intel publications:

- \*SDK-86 MCS-86 System Design Kit Assembly Manual, Order No. 9800697
- \*SDK-86 MCS-86 System Design Kit Monitor Listings, Order No. 9800699
- \*The 8086 Family User's Manual, Order No. 9800722
- \*Application of Intel's 5V EPROM and ROM Family for Microprocessor Systems, Application Note AP-30
- ASM86 Language Reference Manual, Order No. 9800640
- MCS-86 Software Development Utilities Operating Instructions for ISIS-II Users, Order No. 9800639
- MCS 80/85 Absolute Object File Formats Technical Specification, Order No. 9800183
- Intel Component Data Catalog

<sup>\*</sup>Supplied with SDK-86 Kit

## **CONTENTS**



| PAGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | PAGE                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CHAPTER 1 GENERAL INFORMATION Introduction. 1-1 Specifications. 1-1                                                                                                                                                                                                                                                                                                                                                                                                   | Move Command 4-7 Port Input Command 4-8 Port Output Command 4-9 Go Command 4-10                                                                                                                                                                                                                                                                                                                                                                              |
| CHAPTER 2 FUNCTIONAL DESCRIPTION Introduction                                                                                                                                                                                                                                                                                                                                                                                                                         | Single Step Command                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Wait State Generator       2-2         CPU       2-3         Parallel I/O Ports       2-3         RAM       2-4         PROM       2-5         I/O Decode       2-6         Off Board Decode       2-7         Keypad/Display       2-7         Serial Interface       2-8         Bus Expansion       2-10                                                                                                                                                           | CHAPTER 5         SERIAL LOADER         Introduction.       5-1         System Operation       5-1         Loader Commands       5-2         Transfer Hex File Command       5-3         Load Hex File Command       5-4         Exit Command       5-4         System I/O Routines       5-4         Console Input Routine       5-6         Console Output Routine       5-6         Reader Input Routine       5-8         Reader Input Routine       5-8 |
| CHAPTER 3 KEYPAD MONITOR Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reader Input Routine                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Keypad       3-1         Display       3-3         General Operation       3-4         Monitor Commands       3-6         Examine Byte and Examine Word Commands       3-7         Examine Register Command       3-11         Input Byte and Input Word Commands       3-13         Output Byte and Output Word Commands       3-15         Go Command       3-17         Move Command       3-20         Step Command       3-22         Program Listing       3-24 | PERIPHERAL INTERFACING Introduction                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CHAPTER 4 SERIAL MONITOR Introduction. 4-1 Monitor Command Structure 4-2 Monitor Commands 4-2 Substitute Memory Command 4-3 Examine/Modify Register Command 4-5                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |





| TABLE | TITLE                                    | PAGE   | TABLE | TITLE                              | PAGE   |
|-------|------------------------------------------|--------|-------|------------------------------------|--------|
| 2-1   | Wait State Selection                     | . 2-2  | 3-5   | Monitor Command Summary            | . 3-6  |
| 2-2   | Parallel I/O Port Addresses              | . 2-3  | 3-6   | 8086 Registers                     | . 3-11 |
| 2-3   | PROM A29 Decoding                        | . 2-4  | 3-7   | Parallel I/O Port Addressing       |        |
| 2-4   | PROM A26 Decoding                        | . 2-5  | 3-8   | Control Port Addressing            |        |
| 2-5   | PROM A22 Decoding                        | . 2-6  | 4-1   | Monitor Command Summary            |        |
| 2-6   | I/O Port Addresses Assignments           |        | 4-2   | Register Abbreviations             |        |
| 2-7   | PROM A12 Decoding                        | . 2-7  | 4-3   | Parallel I/O Port Addressing       |        |
| 2-8   | Keypad/Display I/O Ports                 | . 2-7  | 4-4   | Control Port Addressing            | . 4-9  |
| 2-9   | Segment Definition                       | . 2-8  | 5-1   | Serial Loader Command Summary      |        |
| 2-10  | Baud Rate Selection                      |        | 6-1   | Serial Interface Connector J7 Pin  |        |
| 2-11  | USART I/O Ports                          | . 2-9  |       | Assignments                        | . 6-1  |
| 2-12  | Serial Port Jumper Matrix                | . 2-10 | 6-2   | Parallel I/O Port Connector J5 Pin |        |
| 3-1   | Hexadecimal Keypad Legend Interpretation | 1 3-2  |       | Assignments                        | . 6-3  |
| 3-2   | Function Key Operation                   | . 3-3  | 6-3   | Parallel I/O Port Connector J6 Pin |        |
| 3-3   | Hexadecimal Display Characters           |        |       | Assignments                        | . 6-3  |
| 3-4   | Register Initialization                  |        | 6-4   | Bus Expansion Pin Assignments      | . 6-4  |



## **ILLUSTRATIONS**

| FIGUR             | TITLE                     | PAGE           | FIGURE | 3                            | TITLE                         | PAGE    | Ε  |
|-------------------|---------------------------|----------------|--------|------------------------------|-------------------------------|---------|----|
| 2-1               | Monitor Memory Allocation | . 2-5          | 3-4    | Parallel I/O                 | Port Configuration            | 3-1     | 3  |
| 2-2               | Detailed Block Diagram    |                | 4-1    | Reserved Me                  | mory                          | 4-      | -1 |
| 3-1<br>3-2<br>3-3 | Keypad Arrangement        | . 3-1<br>. 3-5 | 6-1    | Intellec Micro<br>System Int | ocomputer Develop<br>erfacing | ment 6- | 2  |



## CHAPTER 1 GENERAL INFORMATION

## 1-1. Introduction

This is the user's guide for the MCS-86 System Design Kit. Now that you have completed the assembly and initial checkout of your SDK-86, this guide will provide insight into the operation and function of the kit and also will explore circuit designs that can be implemented either off-board or within the user design area to increase or expand your kit's capabilities. Included within this guide are:

- A description of the SDK-86 circuitry.
- Functional descriptions of the two ROM-resident monitor programs with command examples.
- A description of the "loader" program that is used to perform upload/download program transfers between SDK-86 memory and an Intel microcomputer development system.
- Interfacing and board configuration information for connecting peripheral devices to the SDK-86.
- Appendices describing circuit designs that can be implemented in the user design area including program memory expansion using Intel 2708, 2716 and 2732 EPROM devices.

## 1-2. Specifications

#### Central Processor

CPU: 8086

Clock Frequency: 2.5 MHz or 5 MHz (jumper selectable)

Instruction Cycle Time: 800 ns (5 MHz)

## Memory Type

ROM: 8K bytes 2316/2716

RAM: 2K bytes (expandable to 4K bytes) 2142

## Memory Addressing

ROM: FE000 through FFFFF

RAM: 0 through 7FF (0-FFF with 4K bytes)

#### Input/Output

Parallel: 48 lines (two 8255A's) Serial: RS232 or current loop (8251A)

Baud rate selectable from 110 to 4800 baud

## Interface Signals

CPU Bus: All signals TTL compatible Parallel I/O: All signals TTL compatible Serial I/O: 20 mA current loop or RS232

## Interrupts

External: Maskable and Non-Maskable, Interrupt vector 2 reserved for

non-maskable interrupt (NMI).

Internal: Interrupt vectors 1 (single-step) and 3 (breakpoint) reserved by

monitor.

## **DMA**

Hold Request: Jumper selectable, TTL compatible input.

#### Software

System Monitors: Preprogrammed 2316 or 2716 ROMs

Addresses: FE000 through FFFFF

Monitor I/O: Keypad and Serial (teletypewriter or CRT)

## Literature Supplied

- SDK-86 Assembly Manual
- SDK-86 User's Guide
- SDK-86 Monitor Listings
- The 8086 Family User's Manual

## **Physical Characteristics**

Length: 34.3 cm (13.5 in.) Width: 30.5 cm (12.0 in.) Height: 4.4 cm (1.75 in.)

Weight: Approximately 0.7 kg (1.5 lbs)

## Power Requirements

 $V_{cc}$ : +5 volts (±5%), 3.5 Amperes

V<sub>TTY</sub>: -12 volts (±10%), 0.3 Amperes (required only if teletypewriter or CRT terminal connected to serial interface port)

## Environmental

Operating Temperature: 0 to 40°C

## Accessories Kit (SDK-C86)

- SDK to microcomputer development system interface cable.
- Single-density diskette containing "Loader" program and I/O routine library
- Double-density diskette containing "Loader" program and I/O routine library



## CHAPTER 2 FUNCTIONAL DESCRIPTION

## 2-1. Introduction

This chapter examines the circuits which make up the SDK-86. Also presented in this chapter are the I/O port address assignments for the various devices on the board and a definition of ROM and RAM memory allocated to the SDK-86. The individual circuits can be divided into logical blocks as shown in the detailed block diagram (Figure 2-2) at the conclusion of this chapter. The individual blocks that will be described in this chapter are as follows:

- Clock Generator
- Wait State Generator
- CPU
- Parallel I/O Ports
- RAM
- PROM
- I/O Decode
- Off Board Decode
- Keypad/Display
- Serial Interface
- Bus Expansion

## 2-2. Clock Generator

The clock generator circuit is an Intel 8284 clock generator/driver. The circuit accepts a crystal input which operates at a fundamental frequency of 14.7456 MHz. (14.7456 MHz was selected since this frequency is a multiple of the baud rate clock and also provides a suitable frequency for the CPU.) The clock generator/driver divides the crystal frequency by three to produce the 4.9 MHz CLK signal required by the CPU. Additionally, the clock generator performs a further divide-by-two output called PCLK (peripheral clock) which is the primary clock signal used by the remainder of the circuits.

The clock generator/driver provides two control signal outputs which are synchronized (internally) to the 4.9 MHz CLK signal; RDY (ready) and RST (reset). RST is used to reset the SDK-86 to an initialized state and occurs when the  $\overline{RES}$  input goes low (when power first is applied or when the SYSTM RESET key is pressed). The RDY output is active (logically high) when the RDY1 input from the wait state generator is active. As will be explained in the next section, the RDY1 input is active whenever on board memory is addressed or when a selected number of "wait states" occurs.

A jumper link (W40/W41) is provided for low-speed (2.45 MHz) operation and allows the PCLK signal to be routed to the CLK input of the CPU in place of the CLK output from the clock generator/driver. Note that this is the clock configuration that was selected when the SDK-86 kit was assembled and that this configura-

tion allows on-board memory and I/O operations to be performed without the necessity of wait states. When 8086 operation at the 5 (4.9) MHz rate is desired, simply remove the shorting plug from W40 and install it at W41. For additional information regarding the operation of the 8284 clock generator/driver, refer to *The 8086 Family User's Manual*.

#### NOTE

The SDK-86 kit may be supplied with an 8086 CPU that has a maximum clock input frequency of 4 MHz and therefore only can be operated with the 2.45 MHz clock (shorting plug installed at W40). These 4 MHz versions of the 8086 are noted by a "-4" suffix following the circuit number stamped on the top of the component (i.e., 8086-4).

## 2-3. Wait State Generator

The wait state generator circuit allows wait states to be inserted into the CPU's bus cycle to compensate for a "slow" peripheral I/O or memory circuit that has been interfaced to the expansion bus or to allow on-board memory and I/O operations to function correctly when the CPU is operated at a 5 MHz rate. (The SDK-86 memory and I/O devices do not require wait states when the 2.45 MHz clock is used and require 1 wait state when the 4.9 MHz clock is used.) When one or more wait states are required for proper CPU operation, the shorting plug originally installed at W27 (0 wait states) is removed and is positioned over the header pins corresponding to the number of wait states to be inserted into the bus cycle according to the following table.

Table 2-1. Wait State Selection

| Plug Position | Wait States | Plug Position | Wait States |
|---------------|-------------|---------------|-------------|
| W27*          | 0           | W31           | 4           |
| W28           | 1           | W32           | 5           |
| W29           | 2           | W33           | 6           |
| W30           | 3           | W34           | 7           |

<sup>\*</sup>Omitting the wait state shorting plug is equivalent to 0 wait states.

Referring to the block diagram (Figure 2-2), the wait state generator is cleared following every read, write or interrupt cycle and subsequently is enabled at the beginning of the next read, write or interrupt cycle when the CLR input to the wait state generator goes inactive. When enabled, the wait state generator (a 74LS164 shift register) begins to shift a "one" through the register. When the selected number (0-7) of shifts have occurred, the jumpered output goes active which, coupled to the RDY1 input of the clock generator/driver, causes the clock generator's RDY output to the CPU to go active.

When a wait state is selected, on-board I/O operations are subject to the number of wait states selected, while on-board memory operations are performed without the wait state restriction. As shown on the block diagram, the RDY1 input to the clock generator/driver originates either from the wait state generator or from a three-input AND gate. The output from the gate is active during on-board memory read and write operations (M/IO and OFF BOARD high). The jumper link (W39) at one input to the AND gate, when installed, permanently disables the gate and causes on-board memory operations to be subject to the number of wait states selected. Note that it may be necessary to install this link if "slow" ROM or RAM on-board memory is added.

## 2-4. CPU

Information on the operation, function and instruction set of the 8086 CPU is contained in *The 8086 Family User's Manual* and is not repeated in this publication. Several points regarding the implementation of the 8086 CPU in the SDK-86 kit should be noted.

- The 8086 is used in the minimum mode (MN/ $\overline{\text{MX}}$  input held logically high).
- The INTR, TEST and HOLD inputs to the 8086 were disabled by the shorting plugs installed in header W36-W38 when the kit was assembled. When a peripheral circuit is interfaced to the bus expansion logic and requires the use of any of these signals, the corresponding shorting plugs must be removed.
- When the SDK-86 is reset, the 8086 executes the instruction at location FFFF0H. The instruction at this location is an inter-segment direct jump to the beginning of the monitor program that resides in ROM locations FF000H to FFFFFH.
- The 8086's NMI (non-maskable interrupt) input originates from the INTR key and, when pressed, causes the CPU to save the current system status (pushing the IP, CS and FL register contents onto the stack after clearing the IF and TF flags) and to perform an indirect long jump through RAM location 08H (interrupt vector 2). Note that locations 08H through 0BH are initialized by the monitor on reset to contain the address of the monitor's interrupt routine.
- The maskable interrupt (INTR) is not used by the SDK-86, but is available to peripheral circuits through the expansion bus. To use the maskable interrupt, an interrupt vector pointer must be provided on the data bus when INTA is active. When there is more than one source for an interrupt, an interrupt priority resolution circuit must be provided (e.g., an Intel 8259A).

## 2-5. Parallel I/O Ports

The parallel I/O ports consist of two Intel 8255A programmable peripheral interface circuits. These two circuits each contain three 8-bit input/output data ports (designated ports A, B and C) and one write-only control port. The 8255A circuit that interfaces with the low-order data byte (D0-D7) is designated port 2 (P2), and the 8255A circuit that interfaces with the high-order data byte (D8-D15) is designated port 1 (P1). All ports can be addressed individually (e.g., port P1A, P2C, P1 Control, etc.) or a corresponding pair of ports (P1A and P2A, P1B and P2B or P1C and P2C) can be addressed simultaneously to form a single 16-bit wide data port.

The I/O port address assignments for the two parallel I/O port circuits are defined in the following table.

Table 2-2. Parallel I/O Port Addresses

| Port       | Address | Port       | Address |
|------------|---------|------------|---------|
| P2A        | FFF8    | P1A        | FFF9    |
| P2B        | FFFA    | P1B        | FFFB    |
| P2C        | FFFC    | P1C        | FFFD    |
| P2 Control | FFFE    | P1 Control | FFFF    |

During byte operations, the I/O decode logic generates the appropriate  $\overline{CS}$  (chip select) input (HIGH PORT SELECT or LOW PORT SELECT), while during word operations, the P2 port address is used to address the desired pair of ports, and the

I/O decode logic generates both HIGH PORT SELECT and LOW PORT SELECT coincidently. More detailed information on the operation and programming of the 8255A can be found in the *Intel Component Data Catalog*.

## 2-6. RAM

The standard SDK-86 includes 2K bytes of random access memory (RAM) and on-board provision for the installation of an additional 2K bytes. RAM is located at the low end of memory (locations 0H through 07FFH or 0H through 0FFFH). The memory addressing arrangement of the 8086 CPU allows simultaneous reading or writing of a full 16 bits (two adjacent byte locations) or the reading or writing of either the high (D8-D15) or low (D0-D7) byte.

RAM is enabled by the appropriate output(s) from RAM decode PROM A29 and by a high level on the  $M/\overline{10}$  control line (memory operation). The PROM (A29) is enabled by the inactive (low) state of the A19 address bit (indicating an address below 80000H) at its  $\overline{CS1}$  input. The PROM decodes  $\overline{BHE}$  and the A0 and A11 through A18 address bits. When the A12 through A18 address bits are inactive, an address below 1000H is indicated. The A11 address bit determines if the address is between 0H and 07FFH (A11 inactive) or between 0800H and 0FFFH (A11 active). The A0 address bit and  $\overline{BHE}$  determine the byte or bytes enabled. The following table defines the PROM decoding.

Table 2-3. PROM A29 Decoding

| Р                | ROM In | puts |    | F  | PROMO | utputs* |      | Byte(s) Selected         |  |
|------------------|--------|------|----|----|-------|---------|------|--------------------------|--|
| A12-A18          | A11    | BHE  | A0 | 04 | О3    | 02      | 01   | (Address Block)          |  |
| 0                | 0      | 0    | 0  | 1  | 1     | 0       | 0    | Both Bytes (0H-07FFH)    |  |
| 0                | 0      | 0    | 1  | 1  | 1     | 0       | 1    | High Byte (0H-07FFH)     |  |
| 0                | 0      | 1    | 0  | 1  | 1     | 1       | 0    | Low Byte (0H-07FFH)      |  |
| 0                | 1      | 0    | 0  | 0  | 0     | 1       | 1    | Both Bytes (0800H-0FFFH) |  |
| 0                | 1      | 0    | 1  | 0  | 1     | 1       | 1    | High Byte (0800H-0FFFH)  |  |
| 0                | 1      | 1    | 0  | 1  | 0     | 1       | 1    | Low Byte (0800H-0FFFH)   |  |
| All other states |        |      | 1  | 1  | 1     | 1       | None |                          |  |

<sup>\*</sup> A "0" on the output enables the corresponding RAM byte.

RAM itself is addressed by the A1 through A10 address bits and is controlled (read or write) by the  $\overline{RD}$  and  $\overline{WR}$  signals.

The first 256 (decimal) byte locations of RAM (locations 0H through 0FFH) are reserved by the monitor program. The following illustration shows the actual monitor allocations within this block.



Figure 2-1. Monitor Memory Allocation

## 2-7. PROM

The SDK-86 kit includes 8K bytes of PROM; 4K bytes (in two 2K × 8, 2316 ROM or 2716 EPROM devices) containing the keypad monitor program and 4K bytes (in another set of 2K × 8 ROMs or EPROMs) containing the serial monitor program. The 8K bytes of PROM are located at the high end of memory (locations FE000H through FFFFFH). The principle system monitor program (keypad or serial) resides in locations FF000H through FFFFFH (sockets A27 and A30). The remaining 4K locations at sockets A36 and A37 (locations FE000H through FEFFFH) can be used for the other monitor program or for user PROM or ROM program storage.

PROM is enabled by the corresponding output from PROM decode PROM A26 and by the  $\overline{BHE}$  and address bit A0 inputs. PROM A26 decodes the M/ $\overline{IO}$  signal and the A12 through A19 address bits to determine which 4K bytes (FE000H-FFFFH or FF000H-FFFFFH) are to be addressed, while the  $\overline{BHE}$  and A0 inputs enable either high- or low-order byte or word (both bytes) output.

Referring to sheet 1 of the SDK-86 schematic diagram, two additional PROM enable outputs (not shown on the block diagram) are provided. These outputs ( $\overline{CSX}$  and  $\overline{CSY}$ ) are routed to bus expansion connector J2 to permit two additional 4K bytes of PROM or ROM (at locations FC000H-FCFFFH and FD000H-FDFFFH) to be incorporated without requiring external address decoding logic.

Table 2-4 defines the PROM's address decoding.

Table 2-4. PROM A26 Decoding

|                  | PROM Inp |     | PROM ( | Outputs' | PROM Address |    |    |                     |
|------------------|----------|-----|--------|----------|--------------|----|----|---------------------|
| M/IO             | A14-A19  | A13 | A12    | 04       | О3           | 02 | 01 | Block Selected      |
| 1                | 1        | 1   | 1      | 1        | 1            | 1  | 0  | FF000H-FFFFFH       |
| 1                | 1        | 1   | 0      | 1        | 1            | 0  | 1  | FE000H-FEFFFH       |
| 1                | 1        | 0   | 1      | 1        | 0            | 1  | 1  | FD000H-FDFFFH (CSX) |
| 1                | 1        | 0   | 0      | 0        | 1            | 1  | 1  | FC000H-FCFFFH (CSY) |
| All other states |          |     |        | 1        | 1            | 1  | 1  | None                |

<sup>\*</sup> A ''0'' on the output enables the corresponding PROM address block.

## 2-8. I/O Decode

I/O decode PROM A22 is enabled by a low level  $M/\overline{IO}$  input (indicating an I/O operation) and an address between FE00H and FFFFH (address bits A11 through A15 active). When enabled, the PROM decodes  $\overline{BHE}$  and the A0 and A3 through A10 address bits to generate the corresponding I/O port select signal(s) according to Table 2-5.

Table 2-5. PROM A22 Decoding

| PROM Inputs |                  |    |     |    | PROM Outputs*          |                       |                    |             |  |  |  |
|-------------|------------------|----|-----|----|------------------------|-----------------------|--------------------|-------------|--|--|--|
| A5-A10      | A4               | А3 | BHE | A0 | O4<br>HIGH PORT SELECT | O3<br>LOW PORT SELECT | O2<br>USART SELECT | O1<br>KDSEL |  |  |  |
| 1           | 0                | 1  | 0   | 0  | 1                      | 1                     | 1                  | 0           |  |  |  |
| 1           | 0                | 1  | 1   | 0  | 1                      | 1                     | 1                  | 0           |  |  |  |
| 1           | 1                | 0  | 0   | 0  | 1                      | 1                     | 0                  | 1           |  |  |  |
| 1           | 1                | 0  | 1   | 0  | 1                      | 1                     | 0                  | 1           |  |  |  |
| 1           | 1                | 1  | 0   | 0  | 0                      | 0                     | 1                  | 1           |  |  |  |
| 1           | 1                | 1  | 0   | 1  | 0                      | 1                     | 1                  | 1           |  |  |  |
| 1           | 1                | 1  | 1   | 0  | 1                      | 0                     | 1                  | 1           |  |  |  |
| -           | All other states |    |     |    | 1                      | 1                     | 1                  | 1           |  |  |  |

<sup>\*</sup> A "0" on the output selects the corresponding I/O device.

Table 2-6 defines the individual I/O port address assignments.

Table 2-6. I/O Port Address Assignments

| Port Address                                     | Port Function                                                                                                                                                                                             |
|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000<br>to<br>FFDF                               | Open                                                                                                                                                                                                      |
| FFE8 E9 EA EB EC ED EE FFEF                      | Read/Write 8279 Display RAM or Read 8279 FIFO Read 8279 Status or Write 8279 Command Reserved Reserved                                                                                                    |
| FFF0<br>F1<br>F2<br>F3<br>F4<br>F5<br>F6<br>FFF7 | Read/Write 8251A Data  Read 8251A Status or Write 8251A Control  Reserved  Reserved                                                                                                                       |
| FFF8 F9 FA FB FC FD FE FFFF                      | Read/Write 8255A Port P2A Read/Write 8255A Port P1A Read/Write 8255A Port P2B Read/Write 8255A Port P1B Read/Write 8255A Port P2C Read/Write 8255A Port P1C Write 8255A P2 Control Write 8255A P1 Control |

## 2-9. Off Board Decode

The off board decode logic is responsible for the generation of the OFF BOARD signal. This signal is used by the wait state generator to force off-board memory operations to be subjected to the number of wait states selected and also is responsible for the generation of the BUFFER ON signal that is used to enable the data transceivers on the expansion bus during both I/O operations and off-board memory accesses.

Off board decode PROM A12 accepts the A12 through A19 address bits and the M/IO signal to generate the OFF BOARD signal when off-board memory locations are addressed. Table 2-7 defines the PROM decoding. Note that the table shows the inactive states in which the PROM does not generate the OFF BOARD signal.

|      | PROM Inputs      |     |     |     |     |     |     |     | PROM Output  | Corresponding                 |
|------|------------------|-----|-----|-----|-----|-----|-----|-----|--------------|-------------------------------|
| M/IO | A19              | A18 | A17 | A16 | A15 | A14 | A13 | A12 | (01)         | Address Block                 |
|      |                  |     |     |     |     |     |     |     | 4 ( 1 1      | OLI OFFELL (On Brand BANA)    |
| ו ו  | 0                | 0   | 0   | 0   | U   | 0   | 0   | 0   | 1 (inactive) | 0H-0FFFH (On-Board RAM)       |
| 1    | 1                | 1   | 1   | 1   | 1   | 1   | 1   | 0   | 1 (inactive) | FE000H-FEFFFH (On-Board PROM) |
| . 1  | 1                | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1 (inactive) | FF000H-FFFFFH (On-Board PROM) |
|      | All other states |     |     |     |     |     |     |     | 0 (active)   | 01000H-FDFFFH (Off-Board)     |

Table 2-7. PROM A12 Decoding

The OFF BOARD signal also is generated when an off-board I/O port is addressed (port addresses 0H through 0FFDFH). During an I/O operation, the gating shown above the PROM on the block diagram is enabled by the low state  $M/\overline{IO}$  signal and generates the OFF BOARD signal if any of the A5 through A15 address bits is at a low state (an address below 0FFE0H).

## 2-10. Keypad/Display

The keypad/display logic is centered around an Intel 8279 Keyboard/Display Controller. The 8279 is responsible for the debouncing of the keys, the coding of keypad matrix and the refreshing of the display elements.

As stated in Section 2-8, the 8279 occupies two I/O ports within the on-board I/O address space and, since the 8279 is interfaced to the lower byte of the data bus (D0-D7), both ports have even-numbered port addresses (FFE8H and FFEAH). The individual 8279 port functions are determined by the A1 address bit and the  $\overline{RD}$  and WR signals as noted in Table 2-8.

Table 2-8. Keypad/Display I/O Ports

| 8  | 279 Inpu | t  | 5            |                                   |
|----|----------|----|--------------|-----------------------------------|
| A1 | RD       | WR | Port Address | Port Function                     |
| 0  | 0        | 1  | FFE8H        | Read Display RAM or Keyboard FIFO |
| 0  | 1        | 0  | FFE8H        | Write Display RAM                 |
| 1  | 0        | 1  | FFEAH        | Read Status                       |
| 1  | 1        | 0  | FFEAH        | Write Command                     |

Since the A2 address bit is not decoded by the I/O decode PROM, port addresses FFECH and FFEEH are decoded as port addresses FFE8H and FFEAH, respectively. As noted in Table 2-6, these two additional addresses are reserved.

The monitor program, through the write command port, arranges the 8279 as follows:

- Eight digit, 8-bit, left entry display and encoded scan keyboard with 2-key lockout (keyboard/display mode set command; byte value 00H).
- A prescale factor of 25 to provide 5 ms keyboard and display scan times and a 10 ms debounce time (program clock command; byte value 039H).

Additional information regarding the operation and programming of the 8279 can be found in the *Intel Component Data Catalog*.

Referring again to the block diagram, since the encoded scan keyboard mode is specified, the SL0 through SL3 outputs represent a binary count. The 7445 (a BCD to 10-line decoder) converts the binary count to eight, single-line outputs (two outputs are unused) which are used to enable the individual display elements. The SL0 through SL2 outputs additionally are routed to a 74LS156 (configured as a 3- to 8-line decoder) to provide the three row scan signal inputs to the keypad switch matrix. The outputs from the switch matrix, at the RL0 through RL7 inputs to the 8279, represent the eight switch columns (see sheet 7 of the SDK-86 schematic). When a switch is pressed while its row is being scanned, the corresponding column is enabled. The 8279 uses the enabled column bit value and its row scan value (SL0-SL2) to generate a 6-bit code representing the key pressed. This is the code that is stored in the FIFO and accessible to the CPU through the read keyboard FIFO I/O port.

The A0 through A3 and B0 through B3 outputs from the 8279 form a single 8-bit parallel output containing the individual segment enable bits. Table 2-9 defines the correlation between the individual bits and the display element segments (a high level output turns on the corresponding display segment).

| Segment | Segm

Table 2-9. Segment Definition

| a |             |
|---|-------------|
| b |             |
| С |             |
| d |             |
|   |             |
|   | a<br>b<br>c |

Segment

Enabled

## 2-11. Serial Interface

The serial interface is based on an Intel 8251A USART (Universal Synchronous/Asynchronous Receiver/Transmitter) which is operated in the asynchronous mode. An associated baud rate generator provides jumper-selectable baud rates ranging from 75 to 4800 baud for use by the USART. The serial port jumper matrix is used to configure the USART's input/output signals at serial interface connector J7 for "stand alone" or "MDS slave" operation with either teletypewriter (20 mA current loop) or CRT terminal (RS232) interface capability.

The monitor program, by writing a mode command of OCFH to the USART's control port, configures the USART for:

- 8-bit character length
- Parity disabled
- Two stop bits
- Baud rate factor of 64x

The baud rate generator (a 74LS393 dual 4-bit binary counter) uses the 614.4 kHz signal (PCLK/4) to provide a series of baud rate frequencies. Since the USART is operated in the 64x mode, these frequencies are 64 times the corresponding baud rate. Table 2-10 defines the baud rate selection and corresponding baud rate generator output frequency.

**Shorting Plug** Output **Baud Position** Frequency Rate W25 307.2 kHz 4800 W24 153.6 kHz 2400 76.8 kHz 1200 W23 W22 38.4 kHz 600 300 W21 19.2 kHz 150 W20 9.6 kHz 75 W19 4.8 kHz 110 W20, W26 6.98 kHz

Table 2-10. Baud Rate Selection

Referring to sheet 9 of the SDK-86 schematic, the 110 baud rate is derived from the 76.8 kHz signal at the 2A input to the second binary counter. When the shorting plug at W26 is installed, the NAND gate on the 2QA, 2QB and 2QD outputs clears the second binary counter on the count of eleven to provide the required 6.98 kHz signal at the 2QC output.

The USART occupies two I/O ports within the on-board I/O address space and, since the USART is interfaced to the lower byte of the data bus (D0-D7), both ports have even-numbered port addresses (FFF0H and FFF2H). The individual USART port functions are determined by the A1 address bit and the  $\overline{RD}$  and  $\overline{WR}$  signals as noted in Table 2-11.

|                  | USART Inpu       | ıt               | Port Addresses                   | Port Function                                                                   |
|------------------|------------------|------------------|----------------------------------|---------------------------------------------------------------------------------|
| A1               | RD               | WR               | Port Addresses                   | Port Function                                                                   |
| 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 1<br>0<br>1<br>0 | FFF0H<br>FFF0H<br>FFF2H<br>FFF2H | Read USART Data<br>Write USART Data<br>Read USART Status<br>Write USART Control |

Table 2-11. USART I/O Ports

Since the A2 address bit is not decoded by the I/O decode PROM, port addresses FFF4H and FFF6H are decoded as port addresses FFF0H and FFF2H, respectively. As noted in Table 2-6, these two additional addresses are reserved.

The serial port jumper matrix determines the individual pin assignments of the USART's input/output signals at connector J7 and the signal definition (current loop or RS232) and polarity. Table 2-12 defines the shorting plugs to be installed for the various interface configurations.

Table 2-12. Serial Port Jumper Matrix

| Interface<br>Configuration       | Shorting Plugs<br>Installed | PC Board<br>Silkscreen |
|----------------------------------|-----------------------------|------------------------|
| STAND ALONE<br>CRT TERMINAL      | W1-W5                       | ∟ CRT →                |
| STAND ALONE<br>TELETYPEWRITER    | W8-W16                      | ∟ TTY ⊐                |
| INTELLEC SLAVE<br>CRT TERMINAL   | W3-W7                       | ∟ MDS- →               |
| INTELLEC SLAVE<br>TELETYPEWRITER | W14-W18                     | ∟ MDS- ⊐               |

Additional information regarding the operation and programming of the 8251A USART can be found in the *Intel Component Data Catalog*.

## 2-12. Bus Expansion

The bus expansion logic allows peripheral circuits to be interfaced to the SDK-86. The bus expansion logic, which consists of the control transceivers and drivers, the data transceivers and the address latches, provides all required address, data and control signals for either on-board (user design area) or off-board interfacing of peripheral circuits connected to bus expansion connectors J1/J2 and J3/J4.

The control transceivers (an Intel 8286 bidirection bus driver) determine the source of the five bidirection control signals. When a peripheral "master" device is granted bus control by the 8086 CPU, the  $\overline{\text{HLDA}}$  signal at the transceiver's transmit (T) input is active and causes the transceivers to function as receivers (origin of the control signals is from the peripheral circuit). Conversely, while the 8086 has control of the bus,  $\overline{\text{HLDA}}$  is inactive, and the control signals originate from the 8086 CPU.

The (control) drivers (a 74LS244 three-state latch) enable the associated 8086 CPU control and status signals onto the expansion bus while the 8086 has control of the bus (HLDA inactive) and, when bus control is granted to the peripheral circuit (HLDA active), the drivers are placed in their high-impedance state.

The data transceivers (two Intel 8286 bidirectional bus drivers) determine the source of the high- and low-order data bytes during off-board memory and I/O operations and interrupt acknowledge cycles. Referring to the block diagram, the transceivers are enabled by the  $\overline{BUFFER}$  ON signal. This signal is active during the T<sub>2</sub> to T<sub>4</sub> instruction cycles ( $\overline{DEN}$  active) for an off-board memory and I/O operation ( $\overline{OFF}$   $\overline{BOARD}$  active) or an interrupt acknowledge cycle ( $\overline{INTA}$  active). When the transceivers are enabled, the state of the  $\overline{DT/R}$  signal at the T input determines the direction of the transceivers.

The expansion bus address lines (and the  $\overline{BHE}$  signal) originate directly from the address latches (three 74S373 three-state latches) when the 8086 has control of the bus (HLDA inactive). When bus control is granted to the peripheral device (HLDA active), the latches are placed in their high-impedance state.



Figure 2-2. Detailed Block Diagram



## CHAPTER 3 KEYPAD MONITOR

## 3-1. Introduction

This chapter describes your "interaction" or "how you communicate" with your MCS-86 System Design Kit through the keypad monitor program. The monitor program resides in 4K bytes of ROM (Read Only Memory) at the upper end of memory. The program is "initialized" or ready whenever power is turned on or any time the SYSTM RESET key is pressed and allows you to perform the following operations using the keypad and display.

- Examine and modify registers within the 8086 microprocessor.
- Examine and modify memory locations.
- Enter and initiate execution of your own programs or subroutines.
- Evaluate execution (debug) of your program through the monitor's single-step and breakpoint facilities.
- Move selected blocks of memory from one location to another.
- Write or read data to or from an I/O port.

## 3-2. Keypad

With the keypad monitor program, you enter both commands and data by pressing individual keys of the keypad. (The monitor communicates with you through the display.) As shown in Figure 3-1, the keypad is divided into two logical groups; the 16 hexadecimal keys on the right-hand side and the eight function keys on the left-hand side.

Most of the hexadecimal keys have combined functions as noted by their individual legends. The small letters appearing under the hexadecimal key values are acronyms for individual monitor commands and 8086 register names. Acronyms to the left of the slash sign are monitor commands, and acronyms to the right of the slash sign are 8086 register names. The function of a hexadecimal key at any one time is dependent on the current state of the monitor and what the monitor is expecting as input. Table 3-1 defines both the commands and registers associated with the hexadecimal keys.



Table 3-1. Hexadecimal Keypad Legend Interpretation

| Hexadecimal      | Command      |                  | Register |                     |
|------------------|--------------|------------------|----------|---------------------|
| Key              | Acronym      | Name             | Acronym  | Name                |
| 0<br>EB/AX       | ЕВ           | Examine Byte     | AX       | Accumulator         |
| 1<br>ER/BX       | ER           | Examine Register | вх       | Base                |
| 2<br>GO/CX       | GO           | Go               | сх       | Count               |
| 3<br>ST/DX       | ST           | (Single) Step    | DX       | Data                |
| 4<br>IB/SP       | IB           | Input Byte       | SP       | Stack Pointer       |
| 5<br>OB/BP       | ОВ           | Output Byte      | ВР       | Base Pointer        |
| 6<br>MV/SI       | MV           | Move             | SI       | Source Index        |
| 7<br>EW/DI       | EW           | Examine Word     | DI       | Destination Index   |
| 8<br>IW/CS       | IW           | Input Word       | cs       | Code Segment        |
| 9<br>ow/DS       | ow           | Output Word      | DS       | Data Segment        |
| A<br>/ss         | none         | N/A              | ss       | Stack Segment       |
| B <sub>/ES</sub> | none         | N/A              | ES       | Extra Segment       |
| C<br>/IP         | none         | N/A              | IP       | Instruction Pointer |
| D <sub>/FL</sub> | none         | N/A              | FL       | Flag                |
| Е                | none         | N/A              | none     | N/A                 |
| F                | none         | N/A              | none     | N/A                 |
|                  | The state of | greene sold in   | 2043/1   |                     |

The individual operation of the eight function keys is defined in Table 3-2.

Table 3-2. Function Key Operation

| Function<br>Key | Operation                                                                                                                                                                                                                                                                                                                           |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYSTM<br>RESET  | The SYSTM RESET key allows you to terminate any present activity and to return your SDK-86 to an initialized state. When pressed, the 8086 sign-on message appears in the display and the monitor is ready for command entry.                                                                                                       |
| INTR            | The INTR (interrupt) key is used to generate an immediate, non-maskable type 2 interrupt (NMI). The NMI interrupt vector is initialized on power up or system reset to point to a routine within the monitor which causes all of the 8086's registers to be saved. Control is returned to the monitor for subsequent command entry. |
| +               | The + (plus) key allows you to add two hexadecimal values. This function simplifies relative addressing by allowing you to readily calculate an address location relative to a base address.                                                                                                                                        |
|                 | The — (minus) key allows you to subtract one hexadecimal value from another.                                                                                                                                                                                                                                                        |
| :               | The : (colon) key is used to separate an address to be entered into two parts; a segment value and an offset value.                                                                                                                                                                                                                 |
| REG             | The <b>REG</b> (register) key allows you to use the contents of any of the 8086's registers as an address or data entry.                                                                                                                                                                                                            |
| ,               | The , (comma) key is used to separate keypad entries and to increment the address field to the next consecutive memory location.                                                                                                                                                                                                    |
| ·               | The • (period) key is the command terminator. When pressed, the current command is executed. Note that when using the Go command, the 8086 begins program execution at the address specified when the key is pressed.                                                                                                               |

## 3-3. Display

Your SDK-86 kit uses the eight-digit display to communicate with you. Depending on the current state of the monitor, the information displayed will be the:

- Current contents of a register or memory location
- An "echo" of a hexadecimal key entry
- A monitor prompt sign
- An information or status message

The display itself is divided into two groups of four characters. The group on the left is referred to as the "address field," and the group on the right is referred to as the "data field." All values displayed are in hexadecimal and follow the format shown in Table 3-3.

Table 3-3. Hexadecimal Display Characters

| Hexadecimal Value | Display Format        |
|-------------------|-----------------------|
| 0                 |                       |
| 1                 | /                     |
| 2                 | ,="                   |
| 3                 | 3                     |
| 4                 | 4                     |
| 5                 | 2<br>3<br>4<br>5<br>6 |
| 6                 | - E                   |
| 7                 | 7                     |
| 8                 | B                     |
| 9                 | 9                     |
| A                 | FI                    |
| В                 | <u> </u>              |
| С                 | Ē                     |
| D                 |                       |
| E                 | d<br>E                |
| F                 | F                     |
|                   | '                     |

## 3-4. General Operation

When using the keypad monitor, you will be prompted through the display as to the input required. Whenever the monitor is expecting a command entry, a minus sign or "dash" appears in the most significant display digit of the address field. Pressing one of the hexadecimal "command" keys (keys 0-9) when the dash is displayed is interpreted as a command entry. When the key is pressed, the dash disappears and a decimal point (or decimal points) appears in the least significant display digit (or least significant digits) of the address field to indicate that subsequent keypad entry will be directed to the address field. Note that depending on the command, characters also may appear within the address and data fields. Monitor operation from this point is determined by the actual command entered. Refer to Sections 3-6 through 3-12 for individual command format and operation.

Following power-on or whenever the **SYSTM RESET** key is pressed, the monitor initializes the SDK-86 and displays the monitor sign-on message ("86" in the two least-significant digits of the address field and the program's version number in the two least-significant digits of the data field) and the command prompt character (dash) in the most significant digit of the address field. When initialized, the following 8086 registers are set to the values shown in Table 3-4 by the monitor.

SDK-86 Keypad Monitor

Table 3-4. Register Initialization

| Register                                                                                                                        | Value                                     |
|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| CS (Code Segment) DS (Data Segment) ES (Extra Segment) SS (Stack Segment) IP (Instruction Pointer) FL (Flag) SP (Stack Pointer) | 0H<br>0H<br>0H<br>0H<br>0H<br>0H<br>0100H |

Note that in the above table and in the remainder of this manual, the letter "H" is used to indicate that the associated value is in hexadecimal.

The first 256 memory locations (locations 0H-0FFH) are reserved for the monitor and user stack area as shown in Figure 3-2. (First user-available memory location in RAM is 0100H.)



Figure 3-2. Reserved Memory

Whenever the SDK is powered up or whenever the SYSTM RESET key is pressed, the monitor immediately terminates its present activity and jumps to its initialization routine. This routine initializes interrupt vectors 1 through 3 as follows:

Interrupt 1: Single Step: Used with the Single Step command Interrupt 2: NMI (Non-Maskable Interrupt): Monitors INTR key

Interrupt 3: Breakpoint: Used with the Go command

Whenever the monitor is re-entered as a result of a Single Step, NMI or Breakpoint interrupt, the monitor temporarily stores (pushes) the contents of the 8086 registers onto the user stack and subsequently removes (pops) the register contents from the stack before it prompts for command entry. Since the SP register is initialized to 0100H (base of the stack), the initial stack reserved for the user is 48 bytes (locations D0-0FFH) of which 26 bytes must be reserved for the register contents should one of the above interrupts occur.

Note that in the following command descriptions, the monitor always calculates a 20-bit physical memory address from a 16-bit segment address value and a 16-bit offset address value. The segment address value is entered first, the ":" key is pressed (to separate the two entries), and then the offset address value is entered. The two values entered, which are displaced from one another by four bits, are added together as shown in Figure 3-3 (Segment-Offset Entry) to form the 20-bit physical memory address. If only one address value is entered (the colon must be omitted), it is interpreted by the monitor as an offset address value entry, and the current contents of the code segment (CS) register are used as the segment address value. The CS register contents and the offset address value entered are combined as shown in the Single Offset Entry example of Figure 3-3 to form the 20-bit physical memory address.



Figure 3-3. Physical Address Calculation

## 3-5. Monitor Commands

The keypad monitor is capable of executing ten individual commands. Each command is summarized in Table 3-5 and is described, in detail, within the sections which follow. In both the table and the individual command descriptions, the following command syntax is used:

- Indicates a keyboard key
- [A] Indicates that "A" is optional
- [A]\* Indicates one or more optional occurrences of "A"
- <B> Indicates that "B" is a variable

SDK-86 Keypad Monitor

Table 3-5. Monitor Command Summary

| Command          | Function/Syntax                                                                                               |
|------------------|---------------------------------------------------------------------------------------------------------------|
| Examine Byte     | Displays/modifies memory byte locations  EB <addr> □ [[<data>] □ ]* □</data></addr>                           |
| Examine Word     | Displays/modifies memory word locations  [EW] <addr>⊡ [[<data>] ⊡]* ⊡</data></addr>                           |
| Examine Register | Displays/modifies 8086 register contents  ER <reg key="">[[<data>]⋅]*[⋅]</data></reg>                         |
| Input Byte       | Displays data byte at input port  □B <port addr="">□[□]*□</port>                                              |
| Input Word       | Displays data word at input port  IW <port addr=""> □ [ □ ]* □</port>                                         |
| Output Byte      | Outputs data byte to output port  OB <port addr=""> □ <data>[ □ <data>]* □</data></data></port>               |
| Output Word      | Outputs data word to output port  ow <port addr=""> □ <data>[ □ <data>]* □</data></data></port>               |
| Go               | Transfers control from monitor to user program<br>©○ [ <addr>][ □ <breakpoint addr="">] □</breakpoint></addr> |
| Move             | Moves block of data within memory  MV < start addr> □ < destination addr> □                                   |
| Step             | Executes single user program instruction  ST [ <start addr="">] [[<start addr="">] ] ] * •</start></start>    |

## 3-6. Examine Byte and Examine Word Commands

#### **FUNCTION**

The Examine Byte (EB) and Examine Word (EW) commands are used to examine the contents of selected memory locations. If the memory location can be modified (e.g., a location in RAM), the contents additionally can be updated.

## **SYNTAX**

EB <addr>→[[<data>]→]\*・
EW <addr>→[[<data>]→]\*・

## **OPERATION**

To use either command, press the **EB** key (examine byte) or **EW** key (examine word) when the command prompt character (-) is displayed. When either key is pressed, the decimal point at the right of the address field will light (the rest of the display will be blanked) to indicate that entry from the keyboard will be directed to the address field. From the keypad, enter the memory address of the byte or word to be examined, most significant character first. Note that all memory addresses consist of both a segment value and an offset value. When no segment value is specified, the default segment value is the current contents of the code segment (CS) register. When a segment value is specified, the first address entry is the segment value, a colon (:) is entered as a separator, and the second address entry is the offset value. The capacity of an address field entry is limited to four characters and, if more than four characters are entered for either a segment or offset value, only the last four

characters entered (the four characters currently displayed) are valid. After the address is entered, press the "," key. The data byte or word contents of the addressed memory location will be displayed in the data field, and a decimal point will appear at the right of the data field to indicate that any subsequent hexadecimal keypad entry will be directed to the data field. Note that when using the Examine Word command, the byte contents of the memory location displayed appear in the two least-significant digits of the data field, and the byte contents of the next consecutive memory location (memory address + 1) appear in the two most-significant digits of the data field.

If the contents of the memory location addressed only are to be examined, press the "•" key to terminate the command, or press the "•" key to examine the next consecutive memory location (Examine Byte command) or the next two consecutive memory locations (Examine Word command). To modify the contents of an addressed memory location, key-in the new data from the hexadecimal keypad. Note that the data field is limited to either two (examine byte) or four (examine word) characters and that if more characters are entered, only the characters currently displayed in the field are valid. The data displayed is not updated in memory until either the "•" or "•," key is pressed. If the "•" key is pressed, the command is terminated, and the command prompt character is displayed in the address field. If the "•," key is pressed, the offset address and data contents of the next consecutive memory location (Examine Byte command) or memory locations (Examine Word command) are displayed.

#### **ERROR CONDITIONS**

Attempting to modify a non-existent or read-only (e.g., ROM or PROM) memory location. Note that the error is not detected until the "," or "." key is pressed. When an error is detected, the characters "Err" are displayed with the command prompt character in the address field.

#### **EXAMPLES**

Example 1: Examining a Series of Memory Byte Locations Relative to the CS Register

| KEY        | ADDRESS FIELD | DATA FIELD | COMMENT                                |
|------------|---------------|------------|----------------------------------------|
| SYSTM      | - 8 6         | 1. 1       | System Reset                           |
| 0<br>EB/AX |               |            | Examine Byte Command                   |
| 1<br>ER/BX | 1.            |            | First Memory Location To Be Examined   |
| 9<br>OW/DS | / J.          |            | frish memory cocalion to be examined   |
| ,          | 19            | x x •      | Memory Data Contents                   |
| ,          | I A           | x x.       | Next Memory Location and Data Contents |
| ,          |               | x x.       | Next Memory Location and Data Contents |
| ,          | I L           | x x.       | Next Memory Location and Data Contents |
|            | -             |            | Command Termination/Prompt             |

Example 2: Examining and Modifying Memory Word Location 10H Relative to the DS Register

| KEY            | ADDRESS FIELD | DATA FIELD | COMMENT                                     |
|----------------|---------------|------------|---------------------------------------------|
| SYSTM<br>RESET | - 8 6         | 1. 1       | System Reset                                |
| 7<br>EW/DI     |               |            | Examine Word Command                        |
| REG            | r             |            | Register Input                              |
| 9<br>ow/DS     |               |            | DS Register                                 |
| :              |               |            | Segment/Offset Separator                    |
| 1<br>ER/BX     |               |            | Offset Address                              |
| 0<br>EB/AX     | / D.          |            |                                             |
| ,              |               | X X X X    | Memory Data Contents                        |
| 8<br>IW/CS     |               | 0 0 0 8.   |                                             |
| C<br>/IP       |               | 0 0 8 C.   | New Data to Be Entered                      |
| F              |               | 0 8 C F.   |                                             |
| B              |               | 8 C F b.   | J                                           |
| •              | -             |            | Data Updated, Command<br>Termination/Prompt |

To check that the data was updated successfully, press the **EW** key and enter the memory address (DS:10H). Press the "," key and note that "8CFb" is displayed in the data field.

Example 3: Attempting to Modify PROM

| KEY            | ADDRESS FIELD | DATA FIELD | COMMENT                          |
|----------------|---------------|------------|----------------------------------|
| SYSTM<br>RESET | - 8 6         | 1. 1       | System Reset                     |
| 0<br>EB/AX     |               |            | Examine Byte Command             |
| F              | F.            |            |                                  |
| F              | F F.          |            |                                  |
| 0<br>EB/AX     | F F D         |            | Segment Address                  |
| 0<br>EB/AX     | F F 0 0.      |            |                                  |
| :              | F F D D       |            | Segment/Offset Separator         |
| 0<br>EB/AX     |               |            | Offset Address                   |
| 9              |               | 9 0.       | Data Contents of Location FF000H |
| А              |               | [ ] [] Fl. |                                  |
| 7              |               |            | New Data To Be Entered           |
| ,              | - E           |            | Error Message                    |

The error message (Err) resulted from trying to modify the data contents of a read only memory location. Repeat the keying sequence to see that the memory contents (90H) of location FF000H were unaltered.

SDK-86 Keypad Monitor

## 3-7. Examine Register Command

#### **FUNCTION**

The Examine Register (ER) command is used to examine and, if desired, to modify the contents of any of the 8086's registers.

## **SYNTAX**

ER <reg key>[[<data>]⋅] \*[⋅]

## **OPERATION**

To examine the contents of a register, press the **ER** key when prompted for a command entry. When the key is pressed, the decimal point at the right of the address field will light. Unlike the Examine Byte command, subsequent hexadecimal keypad entry will be interpreted as the register name (the acronym to the right of the slash sign on the key face) rather than its hexadecimal value. When the hexadecimal key is pressed, the corresponding register abbreviation will be displayed in the address field, the 16-bit contents of the register will be displayed in the data field and the decimal point on the right of the data field will light. Table 3-6 defines the 8086 register name, the hexadecimal keypad acronym, the display abbreviation and the sequence in which the registers are examined.

Table 3-6. 8086 Registers

| Register Name                                                                                                                                          | Keypad Acronym                            | Display Abbreviation           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------|
| Accumulator Base Count Data Stack Pointer Base Pointer Source Index Destination Index Code Segment Data Segment Stack Segment Instruction Pointer Flag | AX BX CX DX SP BP SI DI CS DS SS ES IP FL | A b C d SP P SI d S S S E P FL |

When the register contents are displayed (when the decimal point on the right of the data field lights), the register's contents can be modified or the register is said to be "open" for input. Keying in a value from the hexadecimal keypad will be echoed in the display's data field, and the register contents will be updated with the data value displayed when either the "," or "." key is pressed. If the "." key is pressed, the command is terminated, and the command prompt character is displayed. If the "," key is pressed, the abbreviation and contents of the "next" register are displayed and opened for modification according to the order in Table 3-6. Note that the sequence is *not* circular and that pressing the "," key when the flag (FL) register is displayed will terminate the examine register command and return to the command prompt character.

## **EXAMPLES**

Example 1: Examining and Modifying a Register



Example 2: Examining a Series of Registers

| KEY        | ADDRESS FIELD | DATA FIELD | COMMENT                               |
|------------|---------------|------------|---------------------------------------|
| SYSTM      | - 8 6         | [ ], I     | System Reset                          |
| 1<br>ER/BX |               |            | Examine Register Command              |
| 9<br>ow/ds |               | 0 0 0 0.   | Data Segment Register Contents        |
| ,          | 5 5           | 0 0 0 0.   | Stack Segment Register Contents       |
| ,          | E 5           | 0 0 0 0    | Extra Segment Register Contents       |
| ,          | I P           | 0 0 0 0.   | Instruction Pointer Register Contents |
| ,          | FL            | 0 0 0 0.   | Flag Register Contents                |
| ,          | -             |            | Command Termination/Prompt            |

## 3-8. Input Byte and Input Word Commands

## **FUNCTION**

The Input Byte (IB) and Input Word (IW) commands are used to input (accept) an 8-bit byte or 16-bit word from an input port.

#### **SYNTAX**

IB <port addr> [] \* .
IW <port addr> [] \* .

#### **OPERATION**

To use either the Input Byte or Input Word command, press the corresponding hexadecimal key when prompted for command entry. When either the IB or IW key is pressed, the decimal point on the right of the address field will light to indicate that a port address entry is required. Using the hexadecimal keypad, enter the port address of the port to be read. Note that since I/O addressing is limited to 64K (maximum address FFFFH), no segment value is permitted with the port address.

After the port address has been entered, press the "," key. The input byte or word at the addressed port will be displayed in the data field. Again pressing the "," key updates the data field display with the current data byte or word at the addressed input port. Pressing the "." key terminates the command and prompts for command entry.

The SDK-86 includes two 8255A parallel I/O port circuits which can be used with the Input Byte and Input Word commands to input data from peripheral devices. These two circuits are designated P1 and P2. Each circuit, in turn, consists of three individual 8-bit ports which are designated port A, port B, and port C. As shown in Figure 3-4, each port operates independently during byte operations. During word operations, a pair of ports (e.g., P1A and P2A) operate together to form the 16-bit wide data word with P2 corresponding to the low-order byte.



Figure 3-4. Parallel I/O Port Configuration

Table 3-7 defines the individual port addresses. Note that during word operations, the low-order (P2) port address is entered (the corresponding high-order port is addressed automatically).

Table 3-7. Parallel I/O Port Addressing

| Port                                   | Address                                      |  |
|----------------------------------------|----------------------------------------------|--|
| P2A<br>P1A<br>P2B<br>P1B<br>P2C<br>P1C | FFF8<br>FFF9<br>FFFA<br>FFFB<br>FFFC<br>FFFD |  |

The parallel I/O port circuits are programmed for input on power-up or whenever the SYSTM RESET key is pressed. If the circuit(s) previously has been programmed for output, press the SYSTM RESET key (before pressing the command key) or, referring to the next section, output the appropriate byte or word value to the circuit's control port to program the port(s) for input. Additional information regarding the operation of the 8255A parallel I/O port circuit can be found in the *Intel Component Data Catalog*.

## **EXAMPLES**

Example 1: Single Byte Input from Port 0FFH\*

| KEY            | ADDRESS FIELD | DATA FIELD | COMMENT                    |
|----------------|---------------|------------|----------------------------|
| SYSTM<br>RESET | - 8 6         | 1. 1       | System Reset               |
| 4<br>IB/SP     |               |            | Input Byte Command         |
| F              | F.            |            | Port Address               |
| F              | F F.          |            | Port Address               |
| ,              | FF            | X X        | Input Data Byte            |
| •              | -             |            | Command Termination/Prompt |

<sup>\*</sup> Port 0FFH is not provided on the SDK-86

Example 2: Multiple Word Input from Parallel I/O Ports 1B and 2B

| KEY        | ADDRESS FIELD | DATA FIELD | COMMENT                                    |
|------------|---------------|------------|--------------------------------------------|
| SYSTM      | - 8 6         | [ ] I. I   | System Reset (Initializes Ports For Input) |
| 8<br>IW/CS |               |            | Input Word Command                         |
| F          | F.            |            |                                            |
| F          | F F.          |            | Port B Address                             |
| F          | F F F.        |            | FOILB Address                              |
| А          | F F F F       |            |                                            |
| ,          | FFFA          | x x x x    | Input Data Word From Port                  |
| ,          | F F F F       | XXXX       | Input Data Word Again                      |
| ,          | F F F F       | X X X X    | Input Data Word Again                      |
| •          | -             |            | Command Termination/Prompt                 |

# 3-9. Output Byte and Output Word Commands

#### **FUNCTION**

The Output Byte (OB) and Output Word (OW) commands are used to output a byte or word to an output port.

#### **SYNTAX**

#### **OPERATION**

To use either command, press the corresponding hexadecimal key when prompted for command entry. When either the **OB** or **OW** key is pressed, the decimal point on the right of the address field will light to indicate that a port address entry is required. Like the Input Byte and Input Word commands, I/O addresses are limited to 64K, and no segment value is permitted. After the port address is entered, press the "," key. The decimal point on the right of the data field will light to indicate that the data byte or word to be output now can be entered. Using the keypad, enter

the byte or word to be output. After the data is entered, press the "•" key to output the byte or word to the port and to terminate the command or press the "•," key if additional data is to be output to the addressed port.

As mentioned in the previous section, the Output Byte and Output Word commands can be used to program the 8255A parallel I/O port circuits for input or output as well as to output data to the individual ports. The I/O port circuits are programmed for input on power-up or system reset and consequently first must be programmed for output (by outputting the appropriate data byte or word to the circuit's control port) before data can be output to the associated ports. Table 3-8 defines the control port addressing and associated data byte or word to be output to the control port. Additional information regarding the operation of the 8255A parallel I/O port circuit can be found in the *Intel Component Data Catalog*.

Table 3-8. Control Port Addressing

| Port              | Port                    | Data Byte or Word   |                     |  |
|-------------------|-------------------------|---------------------|---------------------|--|
| Number            | Address                 | Input               | Output              |  |
| P2<br>P1<br>P2/P1 | FFFEH<br>FFFFH<br>FFFEH | 9BH<br>9BH<br>9B9BH | 80H<br>80H<br>8080H |  |

#### **EXAMPLES**

Example 1: Output DI Register Contents to Output Port 0C5H\*

| KEY            | ADDRESS FIELD | DATA FIELD | COMMENT                                    |
|----------------|---------------|------------|--------------------------------------------|
| SYSTM<br>RESET | - 8 6         | 1, 1       | System Reset                               |
| 9<br>ow/DS     |               |            | Output Word Command                        |
| C              | Ε.            |            |                                            |
| 5<br>0B/BP     | <i>E</i> 5.   |            | Output Port Address                        |
| 5              | [             | •          | Enable Data Entry                          |
| REG            | [             | r          | Register Input                             |
| 7<br>EW/DI     | [             | x x x x.   | DI Register Contents                       |
| •              | -             |            | Data Output, Command<br>Termination/Prompt |

<sup>\*</sup> Port 0C5H is not provided on the SDK-86

Keypad Monitor

Example 2: Programming Port P1 for Output

**SDK-86** 

| KEY            | ADDRESS FIELD | DATA FIELD | COMMENT                                            |
|----------------|---------------|------------|----------------------------------------------------|
| SYSTM<br>RESET | - 8 6         | [ ], I     | System Reset (Initializes Ports for Input)         |
| 5<br>OB/BP     |               |            | Output Byte Command                                |
| F              | F.            |            |                                                    |
| F              | F F.          |            | P1 Control Port Address                            |
| F              | F F F.        |            |                                                    |
| F              | F F F F.      |            | J                                                  |
| ,              | F F F F       |            | Enable Data Entry                                  |
| 8<br>IW/CS     | F F F F       | [          |                                                    |
| 0<br>EB/AX     | F F F F       | [   B D.   | Control Byte for Output                            |
| •              | -             |            | Control Byte Output, Command<br>Termination/Prompt |

# 3-10. Go Command

# **FUNCTION**

The Go (GO) command is used to transfer control of the 8086 from the keypad monitor program to a user's program in memory.

## **SYNTAX**

GO [<addr>][ □ <breakpoint addr>] □

#### **OPERATION**

To use the Go command, press the GO key when prompted for command entry. When the key is pressed, the current IP (instruction pointer) register contents are displayed in the address field, the byte contents of the memory location addressed by the IP register are displayed in the data field, and the decimal point at the right of the address field lights to indicate that an alternate start address entry can be entered. If an alternate starting address is required, enter the address from the keypad. (When an address is entered, the data field is blanked.) To begin program execution (at the current instruction or alternate program address), press the "•" key. When the key is pressed, the monitor displays an "E" in the most-significant digit of the address field before transferring control to the program.

To illustrate the operation of the Go command, the following sample program can be entered into memory using the Examine Byte command. The program simulates a dice game in which you "throw" a single die. After the program has been entered and after control is passed to the program by the Go command, pressing any keyboard key (other than SYSTM RESET or INTR) starts the die rolling. Again pressing any key stops the die and displays its value (a number between 1 and 6 appears in the leftmost digit of the address field).

#### Sample Program

| Memory<br>Location | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | A  | В  | С  | D  | E  | F  |
|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0100               | 8C | C9 | 8E | D9 | ВА | EA | FF | B0 | D3 | EE | ВА | EA | FF | EC | 24 | 0F |
| 0110               | 74 | FB | E8 | 28 | 00 | вв | 00 | 00 | 43 | 80 | FB | 07 | 74 | F7 | 8B | FB |
| 0120               | 8A | 4D | 47 | 90 | ВА | EA | FF | B0 | 87 | EE | ВА | E8 | FF | 8A | C1 | EE |
| 0130               | ВА | EA | FF | EC | 24 | 0F | 74 | E0 | E8 | 02 | 00 | ЕВ | CD | ВА | EA | FF |
| 0140               | B0 | 40 | EE | ВА | E8 | FF | EC | C3 | 06 | 5B | 4F | 66 | 6D | 7D |    |    |

The sample program consists of 4E hexadecimal locations and is entered into memory beginning at location 100H. After you have entered all of the program data, press the "•" key to terminate the Examine Byte command and to cause the monitor to request a command entry. When prompted, press the GO key and enter the program's starting memory address using a segment value of 10 and an offset value of 0 (10:0). Press the "•" key and note that the display is blanked. Now pressing any keyboard key will start the die rolling, and again pressing any key will stop the die. Note that since the sample program uses the most-significant digit of the address field, the "E" is overwritten.

#### **NOTE**

After the program is entered into memory, it will remain in memory until power is removed and will not be affected by pressing the **SYSTM RESET** key.

To exit from the executing program and return control to the monitor, press either the SYSTM RESET or INTR key. If the SYSTM RESET key is pressed, the monitor is re-entered and the appropriate 8086 registers are initialized. If the INTR key is pressed, the monitor is re-entered, all of the 8086 registers are saved, and the monitor prompts for a command entry. When the monitor is re-entered by pressing the INTR key, pressing the GO key causes the current IP register value (the offset address of the next program instruction to be executed when the INTR key was pressed) and the byte contents of that location (addressed by both the IP and CS registers) to be displayed. Pressing the "." key transfers control from the monitor back to the program at the instruction addressed and program execution continues.

The Go command optionally permits a "breakpoint address" to be entered. A breakpoint address has the same affect as pressing the INTR key while a program is being executed. To enter a breakpoint address, press the "," key after entering the starting address and enter the breakpoint address. Note that when specifying a breakpoint address, the default segment value is either the starting address segment value (if specified) or the current CS register contents (if a segment value is not specified with the starting address). In addition, the location specified by the breakpoint address must contain the first (opcode or prefix) byte of the instruction. When the """ key is pressed, the monitor replaces the instruction at the breakpoint address with an interrupt instruction and saves the "breakpointed" instruction

SDK-86 Keypad Monitor

before transferring control to the user's program. When the program reaches the breakpoint address, control is returned to the monitor, the breakpointed instruction is restored in the program, all registers are saved, and the monitor prompts for command entry to allow any of the registers to be examined. Note that since the breakpointed instruction is restored when control is returned to the monitor, the breakpoint address must be specified each time the program is to be executed with a breakpoint.

#### **ERROR CONDITIONS**

Attempting to breakpoint an instruction in read-only memory.

# **EXAMPLES**

Example 1: Transferring Control to the Sample Program

| KEY            | ADDRESS FIELD | DATA FIELD | COMMENT                                                   |
|----------------|---------------|------------|-----------------------------------------------------------|
| SYSTM<br>RESET | - 8 8         | 1. 1       | System Reset                                              |
| 2<br>GO/CX     |               | X X        | Go Command (IP register offset address and data contents) |
| 1<br>ER/BX     | [ ] I.        |            | Segment (CS Register) Address                             |
| 0<br>EB/AX     | / <i>[]</i> , |            |                                                           |
|                | / I D.        |            | Segment/Offset Separator                                  |
| 0<br>EB/AX     |               |            | Offset Address                                            |
| •              |               |            | Control Transferred To 0100H                              |

Example 2: Entering and Executing a Breakpoint in the Sample Program

| KEY            | ADDRESS FIELD | DATA FIELD | COMMENT                                              |
|----------------|---------------|------------|------------------------------------------------------|
| SYSTM<br>RESET | - 8 6         |            | System Reset                                         |
| 2<br>GO/CX     |               | X X        | Go Command                                           |
| 1<br>ER/BX     |               |            | Segment (CS Register) Address                        |
| 0<br>EB/AX     | / [].         |            |                                                      |
| :              | / I D.        |            | Segment/Offset Separator                             |
| 0<br>EB/AX     |               |            | Offset Address                                       |
| ,              |               |            |                                                      |
| 2<br>GO/CX     | 2.            |            | Breakpoint Offset Address                            |
| 0              |               |            |                                                      |
| •              |               |            | Transfer Control                                     |
| X              | -             | Ьг         | Press Any Key, Breakpoint Reached,<br>Command Prompt |

# 3-11. Move Command

# **FUNCTION**

The Move (MV) command permits a block of data to be moved within memory.

#### **SYNTAX**

#### **OPERATION**

The format of the Move command is unique in that three successive entries are made in the address field. To use the Move command, press the MV key when prompted for command entry. When the key is pressed, three decimal points appear in the address field to indicate that three entries are required. Each time an entry is made, the leftmost decimal point goes out so that the number of decimal points lit at any one time indicates the number of entries still required. The entries are, in order:

- 1. The starting memory address of the block of data to be moved.
- 2. The ending memory address of the block of data to be moved.

3. The starting memory address (destination address) into which the block of data is to be moved.

Note that no segment value is permitted with an ending address and that block moves consequently are limited to 64K bytes.

When the "." key is pressed, the data is moved and the command prompt sign is displayed. Note that when the block of data is moved, the data contained in the original (source) memory locations is *not* altered (unless the destination address falls within the original block of data in which case the overlapping memory locations will be overwritten by the data moved).

Since a move is performed one byte at a time, the Move command can be used to fill a block of memory with a constant. This is accomplished by specifying a destination address that is one greater than the start address. The block of memory locations from start address to end address + 1 will be filled with the value contained in the start address location. (The Examine Byte command can be used to specify the contents of start address.)

#### **ERROR CONDITIONS**

Attempting to move data into read-only or non-existent memory.

#### **EXAMPLES**

Example 1: Moving the Dice Program to Location 0200H

| KEY              | ADDRESS FIELD | DATA FIELD | COMMENT                   |
|------------------|---------------|------------|---------------------------|
| SYSTM<br>RESET   | - 8 6         | 1. 1       | System Reset              |
| 6<br>MV/SI       |               |            | Move Command              |
| 1<br>ER/BX       | !.            |            |                           |
| 0<br>EB/AX       | . 1. 17.      |            | Start Address (0100H)     |
| :                | . 1. []       |            | Statt Address (Vitori)    |
| 0<br>EB/AX       |               |            |                           |
| ,                |               |            |                           |
| 4<br>IB/SP       | . 4.          |            | End Offset Address (04DH) |
| D <sub>/FL</sub> | Ч. с.         |            | End onser Address (04DH)  |
| ,                |               |            |                           |

Example 1: Moving the Dice Program to Location 0200H (Cont'd.)



# 3-12. Step Command

#### **FUNCTION**

The Step (ST) command permits program instructions in memory to be executed individually. With each instruction executed, control is returned to the monitor from the program.

#### **SYNTAX**

ST [<start addr>] : [[<start addr>] : ] \* :

#### **OPERATION**

To use the Step command, press the ST key when prompted for command entry. If a starting address other than the address displayed is required, enter the desired address. When the "," key is pressed, the instruction addressed is executed and the offset address of the next instruction to be executed is displayed in the address field and its associated instruction byte is displayed in the data field. Again pressing the "," key executes the current instruction and steps the program to the next instruction to be executed.

In the example which follows, the first few instructions of the "rolling dice" program are executed using the step command. The following table represents a listing of the beginning of that program. (A complete listing of the "rolling dice" program is included at the end of this chapter.)

| LOCATION                   | CONTENTS                             | SYMB                     | OLIC                                         | COMMENTS                                                                                                    |
|----------------------------|--------------------------------------|--------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| 00<br>02<br>04<br>07<br>09 | 8CC9<br>8ED9<br>BAEAFF<br>B0D3<br>EE | MOV<br>MOV<br>MOV<br>OUT | CX,CS<br>DS,CX<br>DX,0FFEAH<br>AL,0D3H<br>DX | ;DEFINE DATA SEGMENT REGISTER EQUAL<br>;TO CODE SEGMENT REGISTER<br>;CLEAR DISPLAY CONTROL WORD<br>;TO 8279 |
|                            |                                      |                          | ADKEY:                                       |                                                                                                             |
| 0A                         | BAEAFF                               | MOV                      | ,                                            | ;SET UP 8279 COMMAND PORT                                                                                   |
| 0D                         | EC                                   | IN                       | DX                                           | ;READ 8279 FIF0 STATUS                                                                                      |
| 0E                         | 240F                                 | AND                      | AL,0FH                                       | ;MASK ALL BUT FIFO COUNT                                                                                    |
| 10                         | 74FB                                 | JZ                       | READKEY + 3                                  | ;KEEP READING IF ZERO                                                                                       |
| 12                         | E82800                               | CALL                     | READATA                                      | ;DUMMY READ TO UNLOAD<br>:PRESSED KEY FROM FIFO                                                             |
|                            |                                      |                          |                                              |                                                                                                             |

Note that when the program is stepped from the instruction at 10H, the instruction at 0DH is executed again and the instruction at 12H is not executed. This is caused by the JZ (jump zero) instruction at 10H which, since no key can be pressed to "roll

the dice" (the monitor is in control of the keyboard), jumps back to the instruction at 0DH. Continuing to press the "," key will repeat the three instruction sequence (0DH, 0EH, 10H).

#### **RESTRICTIONS**

- 1. If an interrupt occurs prior to the completion of a single-stepped instruction or if a single-stepped instruction generates an interrupt, when the monitor is reentered, the CS and IP registers will contain the address of the interrupt service routine. Consequently, a type 3 (breakpoint) interrupt instruction (0CCH or 0CDH) should not be single-stepped since its execution would step into the monitor.
- 2. An instruction that is part of a sequence of instructions that switches between stack segments (i.e., changes the SS and SP register contents) cannot be single-stepped.
- 3. A MOV or a POP instruction that modifies a segment register cannot be single-stepped. Control is returned to the monitor after the next instruction (the instruction that immediately follows the MOV or POP instruction) is executed.

#### **EXAMPLES**

Example 1: Program Stepping



Example 1: Program Stepping (Cont'd.)



# 3-13. Program Listing

The following is the complete program listing for the "rolling dice" program used in the previous command examples. For more information regarding program operation and interpretation, refer to *The 8086 Family User's Manual* or the *ASM86 Language Reference Manual*, Order Number 9800640.

| LOCATION                               | CONTENTS                                               | SYMB  | OLIC                                          |                                                                     | COMMENTS                                                                                                                                                                                    |
|----------------------------------------|--------------------------------------------------------|-------|-----------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00<br>02                               | 8CC9<br>8ED9                                           | DICE  |                                               | E DS:DICE, CS:DIC<br>NT AT 100<br>CX,CS<br>DS,CX                    | ;DEFINE DATA SEGMENT<br>;REGISTER EQUAL TO                                                                                                                                                  |
| 04<br>07<br>09                         | BAEAFF<br>B0D3<br>EE                                   |       | MOV<br>MOV<br>OUT                             | DX,0FFEAH<br>AL,0D3H<br>DX                                          | ;CODE SEGMENT REGISTER<br>;CLEAR DISPLAY CONTROL<br>;WORD TO 8279                                                                                                                           |
| 0A<br>0D<br>0E<br>10<br>12             | BAEAFF<br>EC<br>240F<br>74FB<br>E82800                 | READI | KEY:<br>MOV<br>IN<br>AND<br>JZ<br>CALL        | DX,0FFEAH<br>DX<br>AL,0FH<br>READKEY + 3<br>READATA                 | ;SET UP 8279 COMMAND PORT<br>;READ 8279 FIFO STATUS<br>;MASK ALL BUT FIFO COUNT<br>;KEEP READING IF ZERO<br>;DUMMY READ TO UNLOAD THE<br>;PRESSED KEY FROM FIFO                             |
| 15                                     | BB0000                                                 | ZERO: | MOV                                           | BX,0000H                                                            | ;INITIALIZE DICE COUNT TO ZERO                                                                                                                                                              |
| 18<br>19<br>1C<br>1E<br>20             | 43<br>80FB07<br>74F7<br>8BFB<br>8A4D4790               | STARI | T:<br>INC<br>CMP<br>JZ<br>MOV<br>MOV          | BX<br>BL,07H<br>ZERO<br>DI,BX<br>CL,CDTBL[DI-1]                     | ;INCREMENT DICE COUNT<br>;IF COUNT EQUALS 7, RESET<br>;COUNT TO 0<br>;PUT COUNT IN DI REGISTER<br>;PUT 7-SEGMENT DISPLAY<br>;CODE IN CL REGISTER,<br>;USE DI AS POINTER INTO<br>;CODE TABLE |
| 24<br>27<br>29<br>2A<br>2D<br>2F<br>30 | BAEAFF<br>B087<br>EE<br>BAE8FF<br>8ACI<br>EE<br>BAEAFF |       | MOV<br>MOV<br>OUT<br>MOV<br>MOV<br>OUT<br>MOV | DX,0FFEAH<br>AL,087H<br>DX<br>DX,0FFE8H<br>AL,CL<br>DX<br>DX,0FFEAH | ;OUTPUT "WRITE DISPLAY" ;CONTROL WORD TO 8279 ;OUTPUT THE DICE COUNT ;TO 8279 DATA PORT ;READ 8279 FIFO STATUS                                                                              |
| 33<br>34<br>36                         | EC<br>240F<br>74E0                                     |       | IN<br>AND<br>JZ                               | DX<br>AL,0FH<br>START                                               | ;MASK ALL BUT FIFO COUNT<br>;KEEP COUNTING IF NO<br>;KEY PRESSED                                                                                                                            |
| 38                                     | E80200                                                 |       | CALL                                          | READATA                                                             | ;DUMMY READ TO UNLOAD<br>;THE PRESSED KEY FROM FIFO                                                                                                                                         |
| 3B                                     | EBCD                                                   |       | JMP                                           | READKEY                                                             | GO READ NEXT KEY PRESSED,                                                                                                                                                                   |

THEN START COUNT AGAIN

|    |        | READATA: |                                         |                                         |
|----|--------|----------|-----------------------------------------|-----------------------------------------|
| 3D | BAEAFF | MOV      | DX,0FFEAH                               | ;OUTPUT "READ DATA"                     |
| 40 | B040   | MOV      | AL,040H                                 | CONTROL WORD TO 8279                    |
| 42 | EE     | OUT      | DX                                      |                                         |
| 43 | BAE8FF | MOV      | DX.0FFE8H                               | :SET UP AND READ 8279                   |
| 46 | EC     | IN       | DX                                      | :DATA PORT, RESULT IN                   |
|    |        |          | :AL REGISTER                            | , , , , , , , , , , , , , , , , , , , , |
| 47 | C3     | RET      | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | :RETURN                                 |
|    |        |          |                                         | , ,                                     |
|    |        | CDTBL    |                                         |                                         |
| 48 | 06     | DB       | 06H                                     | ;7-SEGMENT CODE FOR "1"                 |
| 49 | 5B     | DB       | 05BH                                    | ;7-SEGMENT CODE FOR "2"                 |
| 4A | 4F     | DB       | 04FH                                    | :7-SEGMENT CODE FOR "3"                 |
| 4B | 66     | DB       | 066H                                    | 7-SEGMENT CODE FOR "4"                  |
| 4C | 6D     | DB       | 06DH                                    | :7-SEGMENT CODE FOR "5"                 |
| 4D | 7D     | DB       | 07DH                                    | :7-SEGMENT CODE FOR "6"                 |
|    |        | DICE END |                                         | ,, ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |
|    |        | END      | -                                       |                                         |



# CHAPTER 4 SERIAL MONITOR

# 4-1. Introduction

This chapter defines the command set and command formats supported by the serial monitor program. The serial monitor program itself is contained in 4K bytes of ROM and is designed to operate with either a teletypewriter or CRT terminal that has been connected to serial interface EIA connector J7. (Refer to Chapter 6, Peripheral Interfacing, for connector pin assignments, cabling and board configuration.) The serial monitor performs all of the commands available with the keyboard monitor program and additionally provides the capability of reading and punching paper tape.

When power first is applied or whenever the **SYSTM RESET** key is pressed, the 8086 begins execution of the program which starts at location FF000H. If the keyboard monitor ROM's were installed in the sockets corresponding to starting location FF000H (sockets A27 and A30), the keypad monitor will be in control following power-on or reset. To permit operations using the serial monitor, you either must switch the positions of the monitor ROM sets (so that the serial monitor is in control following power-on or reset), or you must execute a Go command (from the keyboard) to location FE000H (so that control is transferred to the serial monitor's starting location).

The first 256 memory locations (locations 0H-0FFH) are reserved for the monitor and user stack area as shown in Figure 4-1. (First user-available memory location in RAM is 0100H.)



Figure 4-1. Reserved Memory

Whenever the SDK is powered up or whenever the **SYSTM RESET** key is pressed, the monitor immediately terminates its present activity and jumps to its initialization routine. This routine initializes interrupt vectors 1 through 3 as follows:

Interrupt 1: Single Step: Used with the Single Step command

Interrupt 2: NMI (Non-Maskable Interrupt): Monitors INTR key

Interrupt 3: Breakpoint: Used with the Go command

The routine also initializes the 8086's CS, DS, SS, IP and FL registers to 0H and the SP register to 0100H (base of the stack).

Whenever the monitor is re-entered as a result of a Single Step, NMI or Breakpoint interrupt, the monitor temporarily stores (pushes) the contents of the 8086 registers onto the user stack and subsequently removes (pops) the register contents from the stack before it prompts for command entry. Since the SP register is initialized to 0100H, the initial stack reserved for the user is 48 bytes (locations D0-0FFH) of which 26 bytes must be reserved for the register contents should one of the above interrupts occur.

Following power-on/reset (serial monitor at starting location FF000H) or execution of the Go command (serial monitor at starting location FE000H), the serial monitor displays its sign-on message (SDK-86 MONITOR, Vx.x) on one line and a period (".") on the next line to indicate that it is ready to accept command entry. The monitor's current version number appears in the two least-significant digits of the data field display, the numerals "86" appear in the two least-significant digits of the address field display and, with the exception of the SYSTM RESET and INTR keys, the keyboard is disabled.

# 4-2. Monitor Command Structure

When the monitor is ready for a command entry, it outputs a period (".") at the beginning of a new line. This line is referred to as the "command line" and consists of either a one- or two-character command mnemonic followed by from one to three command parameters or "arguments." (If desired for visual separation, a space can be entered between the command mnemonic and the first argument.) When more than one argument is required, a single comma (",") is used between arguments as a delimiter. A command line is terminated either by a carriage return or a comma, depending on the command itself. Commands are executed one at a time and only one command is permitted within a command line.

With the exception of the register abbreviations associated with the X (Examine/Modify Register) command, all arguments are entered as hexadecimal numbers. The valid range of hexadecimal values is from 00 to FF for byte entries and from 0000 to FFFF for word entries (leading zeroes may be omitted). If more than two (byte entries) or four (word entries) digits are entered, only the last two or four digits entered are valid. Address arguments consist of a segment value and an offset value. If a segment value is not entered, the default segment value is the current contents of the code segment (CS) register unless specified otherwise in the command description. When both a segment value and an offset value are entered as an address argument, the first entry is the segment value, and the second entry is the offset value. A colon (":") is entered between the entries as a separator.

Since command execution occurs only after a command terminator is entered, a command entry can be cancelled any time before the terminator is entered by pressing any character that is not legal for the entry expected. When a command is cancelled, the number symbol ("#") is output on the command line, a carriage return and a line feed are issued, and the command prompt character (".") is output on the new line.

# 4-3. Monitor Commands

The serial monitor is capable of executing ten individual commands. Each command is summarized in Table 4-1 and is described, in detail, within the sections which follow. In both the table and the individual command descriptions, the following command syntax is used:

- [A] Indicates that "A" is optional
- [A]\* Indicates one or more optional occurrences of "A"
- <B> Indicates that "B" is a variable
- <cr> Indicates a carriage return is entered

Note that the preceding symbols are used only to clarify the command formats and that they are neither entered nor output on the console device. Also note that in the sections describing the individual commands, output from the monitor is underlined in the examples of command usage, while operator input from the console device is *not* underlined.

Table 4-1. Monitor Command Summary

| COMMAND                     | FUNCTION/SYNTAX                                                                                                                    |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| S (Substitute Memory)       | Displays/modifies memory locations S[W] <addr>,[[<new contents="">],]*<cr></cr></new></addr>                                       |
| X (Examine/Modify Register) | Displays/modifies 8086 registers<br>X[ <reg>][[<new contents="">],]*<cr></cr></new></reg>                                          |
| D (Display Memory)          | Displays block of memory data D[W] <start addr="">[,<end addr="">]<cr></cr></end></start>                                          |
| M (Move)                    | Moves block of memory data<br>M <start addr="">,<end addr="">,<destination addr=""><cr></cr></destination></end></start>           |
| l (Port Input)              | Accepts and displays data at input port I[W] <port addr="">,[,]*<cr></cr></port>                                                   |
| O (Port Output)             | Outputs data to output port O[W] <port addr="">,<data>[,<data>]*<cr></cr></data></data></port>                                     |
| G (Go)                      | Transfers 8086 control from monitor to user program G[ <start addr="">][,<br/>breakpoint addr&gt;]<cr></cr></start>                |
| N (Single Step)             | Executes single user program instruction N[ <start addr="">],[[<start addr="">],]*<cr></cr></start></start>                        |
| R (Read Hex File)           | Reads hexadecimal object file from paper tape into memory R[<br>bias number>] <cr></cr>                                            |
| W (Write Hex File)          | Outputs block of memory data to paper tape punch W[X] <start addr="">,<end addr="">[,<exec addr="">]<cr></cr></exec></end></start> |

# 4-4. Substitute Memory Command

#### **FUNCTION**

The Substitute Memory (S) command is used to examine the byte (S) or word (SW) contents of selected memory locations. If the contents of the memory location can be modified (e.g., a RAM location), the contents additionally can be updated with a new data value entered from the console device.

#### **SYNTAX**

S[W]<addr>,[[<new contents>],]\*<cr>

#### **OPERATION**

To use the Substitute Memory command, enter S or SW when prompted for command entry and enter the address of the memory location to be examined. Note that if a segment address value is not specified, the current contents of the code segment (CS) register are used by default. After the address is entered, enter a comma. The monitor will then output the current data contents of the addressed memory location followed by a dash (the monitor's data entry prompt character) and a space to indicate that the addressed location is open for update. Note that when using the SW command, the byte contents of the next consecutive memory location (memory address + 1) are output first, followed by the byte contents of the actual location addressed. Similarly, when updating memory contents using the SW command, the first byte entry (first two digits) will be written into the next consecutive memory location, and the second byte entry (next two digits) will be written into the addressed memory location.

If only the one memory location is to be examined, enter a carriage return to terminate the command. (If new data was entered, it is updated when the carriage return is entered.) If a series of contiguous memory locations are to be examined and/or updated, enter a comma to advance to the next consecutive memory location (S command) or next two consecutive memory locations (SW command). Again, if the data contents are not to be updated, enter a comma to examine the next memory location, or enter the new data followed by a comma to update the current location and to examine the next location. Entering a carriage return terminates the command.

#### **ERROR CONDITIONS**

Attempting to modify a non-existent or read-only (e.g., ROM or PROM) memory location.

#### **EXAMPLES**

Example 1: Examine ROM location 0FF000H

Example 2: Examine RAM location 050H, relative to the DS register, and update the contents of location 051H to 0F7H

Example 3: Examine and modify top element on stack

Example 4: Examine RAM locations 0100H to 0107H, relative to the CS register, and modify location 0105H from 0FBH to 0BBH

# 4-5. Examine/Modify Register Command

#### **FUNCTION**

The Examine/Modify Register (X) command is used to examine and, if desired, to modify any of the 8086's individual registers or to examine the contents of all of the 8086's registers.

#### **SYNTAX**

X[<reg>][[new contents>],]\*<cr>

#### **OPERATION**

To use the Examine/Modify Register command, enter X when prompted for command entry. If you only wish to examine the current contents of the registers, enter a carriage return. (The contents of all fourteen registers will be output.) If you wish to examine and optionally to modify the contents of an individual register, enter the register's abbreviation according to Table 4-2.

| Register Name                                                                                                                                                   | Abbreviation                                                               |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|
| Accumulator Base Count Data Stack Pointer Base Pointer Source Index Destination Index Code Segment Data Segment Stack Segment Extra Segment Instruction Pointer | AX<br>BX<br>CX<br>DX<br>SP<br>BP<br>SI<br>DI<br>CS<br>DS<br>ES<br>IP<br>FL |  |  |

Table 4-2. Register Abbreviations

When a register abbreviation is entered, the monitor outputs an equal sign ("="), the current register contents, the data prompt character ("-") and a space. If you wish to change the register's contents, enter the new contents followed by a comma (to advance to the next "sequential" register) or a carriage return (to terminate the command). The register sequence is the order shown in Table 4-2. Note that the sequence is not circular and that if a comma is entered after the contents of the flag (FL) register are examined or modified, the monitor returns to the command mode. When a carriage return is entered, the register is updated (if new contents were entered) and the monitor returns to the command mode.

#### **EXAMPLES**

Example 1: Examine the 8086's registers

\_\_X<cr>
AX=89D3 BX=0002 CX=0010 DX=FFEA SP=0100 BP=D3EB SI=9295
DI=0002 CS=0010 DS=0010 SS=0000 ES=0000 IP=000D FL=F046

Example 2: Modify the CS register and examine the next two registers

\_X CS<u>=0000-</u>20, \_DS=0010-\_SS=0000-<cr>

# 4-6. Display Memory Command

#### **FUNCTION**

The Display Memory (D) command is used to output the contents of a block of memory to the console device.

#### **SYNTAX**

D[W]<start addr>[,<end addr>]<cr>

#### **OPERATION**

The command provides a line-formatted output of the memory block bounded by start address and end address (inclusive). Since end address is relative to the segment address value specified or implied with start address (CS register contents if a segment value is not specified with start address), no segment value is permitted with end address and block transfers consequently are limited to 64K bytes or 32K words with each command execution.

To use the Display Memory command, enter D (for byte output) or DW (for word output) when prompted for command entry and then enter start address of the memory data block. If only one byte or word is to be displayed, enter a carriage return, while if a block of memory is to be displayed, enter end address and a carriage return. The monitor will output, beginning on the next line, the starting offset address, the data contents of that location and, when end address is specified, the data contents of a number of consecutive memory locations, each separated by a space. The line format output is arranged so that any subsequent lines (if required) will begin with the offset address of the first byte or word in the line and will consist of a maximum of either sixteen byte entries or eight word entries per line.

The Display Memory command can be cancelled or the output can be stopped at any time by entering control characters from the console device. Control-C immediately terminates the command and returns the monitor to the command entry mode. Control-S stops the output, but does not terminate the command. Control-Q resumes output that has been stopped. The only allowed console input following a Control-S is either a Control-Q or Control-C.

#### **ERROR CONDITIONS**

End address less than the offset value of start address.

#### **EXAMPLES**

Example 1: Display contents of locations 09H through 02AH relative to the DS register

Example 2: Display contents of location 05FFH relative to the CS register

```
_.D 5FF<cr>_05FF_08
```

Example 3: Display contents of locations 0FF000H through 0FF02AH in word mode

.DW FF00:0,2A<cr>

| 0000 | E990 | 0098 | 0072 | 0088 | 4328 | 2029 | 3931 | 3837 |
|------|------|------|------|------|------|------|------|------|
| 0010 | 4920 | 544E | 4C45 | 4320 | 524F | 4050 | 0000 | 4000 |
| 0020 | 7F00 | 007D | 8600 | 5006 | 0000 | 4000 |      |      |

#### 4-7. Move Command

#### **FUNCTION**

The Move command is used to move a block of data within memory.

#### **SYNTAX**

M<start addr>,<end addr>,<destination addr><cr>

#### **OPERATION**

When using the Move command, the contents of the memory block bounded by start address and end address (inclusive) are moved to consecutive memory locations beginning at destination address. As with the D (Display Memory) command, end address is relative to the segment address value specified or implied with start address (if no segment value is specified, the CS register contents are used). Consequently, no segment value is permitted with end address, and block moves are limited to 64K bytes.

Since a move is performed one byte at a time, the Move command can be used to fill a block of memory with a predefined constant. This is accomplished by specifying a destination address which is one greater than start address. The block of memory locations from start address to end address + 1 are filled with the value contained in start address. (The S command is used prior to the Move command to define the constant at start address.)

#### **ERROR CONDITIONS**

Attempting to move data to a read-only (e.g., ROM or PROM) or non-existent memory location.

Specifying an end address value which is less than the offset value of start address.

#### **EXAMPLES**

Example 1: Move the contents of locations 0100H through 014CH to the memory block beginning at 0500H relative to the CS register

\_.M 100,14C,500<cr>

Example 2: Move the contents of locations 0200H through 0250H, relative to the DS register, to the memory block starting at the destination address defined by a segment value equal to the ES register plus 010H, and an offset value of 02CH

\_\_M DS:200,250,ES+10:2C<cr>

Example 3: Fill memory locations 0300H through 0500H, relative to the CS register, with a constant of 04FH

# 4-8. Port Input Command

#### **FUNCTION**

The Port Input (I) command is used to display a byte or word at an input port.

#### **SYNTAX**

#### **OPERATION**

The Port Input command inputs a byte (I command) or word (IW command) from the port specified by port address and displays the byte or word value on the console device. Since I/O addressing is limited to 64K I/O byte addresses, no segment value is permitted with port address. After port address is entered, a comma is required to cause the byte or word at the input port to be displayed at the console. Each subsequent comma entered causes the current data at the addressed input port to be displayed on a new line. A carriage return terminates the command and causes the monitor to prompt for command entry.

When using the Port Input command to input data from the 8255A parallel I/O port circuits, refer to Table 4-3 for the assigned addresses of the individual ports. Note that these circuits are programmed for input on power-on/reset and that if they were last programmed for output, they must be reprogrammed for input (see Section 4-9, Port Output Command).

Table 4-3. Parallel I/O Port Addressing

| Port | Address |
|------|---------|
| P2A  | FFF8    |
| P1A  | FFF9    |
| P2B  | FFFA    |
| P1B  | FFFB    |
| P2C  | FFFC    |
| P1C  | FFFD    |

When using word input (IW command), the port P2 (low-order byte) address is entered as port address.

# **EXAMPLES**

Example 1: Input single word from parallel I/O ports P1A and P2A

Example 2: Input multiple bytes from port 02FAH

# 4-9. Port Output Command

#### **FUNCTION**

The Port Output (O) command is used to output a byte or word to an output port.

#### **SYNTAX**

O[W]<port addr>,<data>[,<data>]\*<cr>

#### **OPERATION**

The Port Output command outputs the byte (O command) or word (OW command) entered as data to the output port specified by port address. Like the Port Input command, I/O addressing is limited to 64K I/O byte addresses, and no segment value is permitted with port address. After entering port address, a comma and the data to be output, a carriage return is entered to cause the data to be output to the port and to terminate the command, or a comma is entered to permit subsequent data output to the addressed port. Data can be output repetitively to the port by entering new data followed by a comma. A carriage return following a data entry outputs the data and terminates the command.

As mentioned in the previous section, the two 8255A parallel I/O port circuits are programmed for input on power-on or system reset. Consequently, to use the Port Output command to output data from the parallel I/O ports, the circuits first must be programmed for output. This is accomplished by using the Port Output command to output a control byte (or word) to the 8255A circuit's control port. Table 4-4 defines the control port addressing and the associated data byte or word to be output to the control port to program the circuits for input or output.

Table 4-4. Control Port Addressing

| Port   |       | Control Byte or Word |             |  |  |
|--------|-------|----------------------|-------------|--|--|
| Number |       | Input Mode           | Output Mode |  |  |
| P2     | FFFEH | 9BH                  | 80H         |  |  |
| P1     | FFFFH | 9BH                  | 80H         |  |  |
| P2/P1  | FFFEH | 9B9BH                | 8080H       |  |  |

#### **EXAMPLES**

Example 1: Program parallel I/O port P2 for output

\_O FFFE,80<cr>

Example 2: Output multiple words to I/O port 020F0H

\_.OW 20F0,BAEA,

- 4CFF,

\_- B0AE,

\_\_ EE47,

\_\_ F9D3<cr>

.

Example 3: Output single byte to parallel I/O port P1C

.O FFFD,3C<cr>

\_\_\_\_\_

#### 4-10. Go Command

#### **FUNCTION**

The Go (G) command is used to transfer control of the 8086 from the serial monitor program to a user's program in memory.

#### **SYNTAX**

G[<start addr>][,<breakpoint addr>]<cr>

#### **OPERATION**

To use the Go command, enter G when prompted for command entry. The current IP (instruction pointer) register contents, the data entry prompt character and the byte contents of the location addressed by the IP register are output. If an alternate starting address is required, enter *start address*. To transfer control from the monitor to the program and to begin program execution, enter a carriage return.

To exit from the executing program and to return control to the monitor, press either the SYSTM RESET or the INTR key on the keypad. If the SYSTM RESET key is pressed, control is transferred to the monitor program that starts at location FF000H, and the appropriate 8086 registers are initialized. If the INTR key is pressed, the program is *interrupted*, the serial monitor is re-entered, *all* of the 8086 registers are saved, and the following message is output followed by a command prompt.

#### @aaaa:bbbb

In the above message, "aaaa" is the current CS register value, and "bbbb" is the current contents of the IP register. (The combined CS and IP register value is the address of the next program instruction to be executed when the INTR key was pressed.) If a subsequent Go command is entered, the current IP register contents ("bbbb") and the data byte addressed by the CS and IP registers are output. When the carriage return is entered, control is transferred back to the program, and execution resumes at the current instruction addressed.

The Go command optionally permits a "breakpoint address" to be entered. A breakpoint address has the same affect as pressing the INTR key while a program is being executed. Note that when specifying breakpoint address, the default segment value is either the start address segment value (if specified) or the current CS register contents (if a segment value is not specified with start address). In addition, the location specified by the breakpoint address must contain the first (opcode or prefix) byte of the instruction. When breakpoint address is specified, the monitor replaces the instruction at the addressed location with an interrupt instruction and saves the "breakpointed" instruction. When the program reaches breakpoint address, control is returned to the monitor, the breakpointed instruction is replaced in the program, all registers are saved, and the monitor outputs the following message followed by a command prompt to allow any of the registers to be examined:

#### BR @aaaa:bbbb

In the above message, "aaaa" is the current CS register value, and "bbbb" is the current IP register value. (The combined register value is the address of the breakpointed instruction.) If a subsequent Go command is entered, execution resumes at the replaced breakpointed instruction. Note that since the breakpointed instruction is replaced when control is returned to the monitor, *breakpoint address* must be specified each time a program to be breakpointed is executed.

#### **ERROR CONDITIONS**

Attempting to breakpoint an instruction in read-only memory.

#### **EXAMPLES**

Example 1: Transfer control to the program at 04C0H, relative to the CS register

\_.G\_0000D-\_EC\_4C0<cr>

Example 2: Transfer control to the program at 10:0H and break at the instruction in location 10:37H

\_.G\_010E-\_24\_10:0,37<cr> \_\_BR\_@0010:0037

# 4-11. Single Step Command

#### **FUNCTION**

The Single Step (N) command is used to execute a single user-program instruction. With each instruction executed, control is returned to the monitor to allow evaluation of the instruction executed.

#### **SYNTAX**

N[<start addr>],[[<start addr>],]\*<cr>

#### **OPERATION**

To use the Single Step command, enter N when prompted for command entry. The monitor will output the current instruction pointer (IP) register contents (the offset address of the next instruction to be executed) and the instruction byte pointed to by the IP (and CS) register. If execution of an instruction at another address is desired, enter start address. If start address includes a segment value, both the CS and IP registers are modified. When the comma is entered, the instruction addressed is executed and control is returned to the monitor. The monitor saves all of the register contents and outputs the address (IP register contents) and instruction byte contents of the next instruction to be executed on the following line. Each time a comma is entered, the addressed instruction is executed and the address and instruction byte contents of the next instruction to be executed are output on a new line.

While using the Single Step command to step through a program, a new start address can be entered without repeating the command entry. When the comma is entered, the instruction addressed is executed and the next instruction's address and byte contents are output. A carriage return terminates the command.

#### RESTRICTIONS

- 1. If an interrupt occurs prior to the completion of a single-stepped instruction or if a single-stepped instruction generates an interrupt, when the monitor is reentered, the CS and IP registers will contain the address of the interrupt service routine. Consequently, a type 3 (breakpoint) interrupt instruction (0CCH or 0CDH) should not be single-stepped since its execution would step into the monitor.
- 2. An instruction that is part of a sequence of instructions that switches between stack segments (i.e., changes the SS and SP register contents) cannot be single-stepped.
- 3. A MOV or a POP instruction that modifies a segment register cannot be single-stepped. Control is returned to the monitor after the next instruction (the instruction that immediately follows the MOV or POP instruction) is executed.

#### **EXAMPLES**

Example 1: Single step a series of instructions beginning at 0100H, relative to the CS register

```
__N 0000- 00 100,
0102- 8E ,
0107- B0 ,
0109- EE ,
010A- BA <cr>
```

Example 2: Single step two instructions and repeat single stepping the second instruction

#### 4-12. Read Hex File Command

#### **FUNCTION**

The Read Hex File (R) command allows the monitor to read an 8086 or 8080 hexadecimal object file from a paper tape and to load the data read from the file into memory.

#### **SYNTAX**

R[<bias number>]<cr>

#### **OPERATION**

To use the Read Hex File command, enter R when prompted for command entry. When the tape is loaded in the reader and ready, enter a carriage return. The data read from the file will be written into memory beginning at each record's load address. If the file is in the 8086 format and includes an execution start address record, the CS and IP registers will be updated with the execution address specified in that record. If the file is in the 8080 format and includes an EOF (end-of-file) record, the IP register is updated with the execution address specified in the EOF record. Note that a segment address value is not used with the 8080 file format; the data read is written into memory locations relative to a segment value of zero and, when an EOF record execution address is specified, the CS register is not changed.

When an optional bias number is specified, it is added to each record's load address to offset the file in memory.

#### **ERROR CONDITIONS**

Tape checksum error.

Attempting to load data into non-existent or read-only memory.

#### **EXAMPLES**

Example 1: Read a file and load the data into memory 256 (decimal) bytes above the load addresses specified in the file.

SDK-86 Serial Monitor

#### 4-13. Write Hex File Command

#### **FUNCTION**

The Write Hex File (W) command allows a block of memory to be output, in either 8086 or 8080 hexadecimal object file format, to a paper tape punch.

#### **SYNTAX**

W[X]<start addr>,<end addr>[,<exec addr>]<cr>

#### **OPERATION**

To use the Write Hex File command, enter W for 8086 file format or WX for 8080 file format and enter start address and end address of the memory block to be output. Note that no segment address value is permitted with end address (the start address segment value is implied) and that if no segment address value is specified with start address, the current CS register value is used. When the carriage return is entered, the following information is punched on the paper tape:

- Six inches of leader (60 null characters)
- An extended address record (8086 format only)
- The data contents of the memory block bounded by start address and end address (inclusive)
- An end-of-file (EOF) record
- Six inches of trailer (60 null characters)

Optionally, an execution address can be specified prior to entering the carriage return. This is the memory address that is loaded into the CS and IP registers (IP register only with 8080 format) when the tape is read with the R command. Depending on the format selected, when execution address is specified, either an execution start address record containing execution address is punched immediately following the tape leader (8086 format) or the offset address value of execution address is punched in the EOF record (8080 format).

When using the 8086 format (W command), the start address segment value (CS register value if a segment value is not specified) is entered (punched) in the extended address record, and the start address offset value is entered in the load address field of the first data record. The segment and offset address values of execution address are entered in the execution start address record (CS register contents if a segment address value is not specified with execution address).

When using the 8080 format (WX command), the start address offset value is punched in the load address field of the first data record. Execution address, if specified, is punched in the EOF record. Note that a segment address value is not permitted with execution address or end address and that the start address segment value is used only to define the starting address of the memory block and that it is not punched on the tape.

The Write Hex File command can be cancelled or stopped at any time by entering control characters from the console device. Control-C cancels the command and prompts for new command entry. Control-S stops the output, but does not cancel the command. Control-Q resumes output that has been stopped. The only console input allowed following a Control-S is either a Control-Q or a Control-C.

Additional information regarding Intel object file formats is available in the MCS 80/85 Absolute Object File Formats Technical Specification, Order Number 9800183 and the MCS-86 Software Development Utilities Operating Instructions for ISIS-II Users, Order Number 9800639.

#### **ERROR CONDITIONS**

Specifying a value for end address that is less than the offset value of start address.

# **EXAMPLES**

Example 1: Output the memory block bounded by 04H and 06DDH, relative to the current CS register, to an 8086 file with an execution address of CS:040H

<u>.</u>

Example 2: Output the memory block bounded by FF200H and FF2FFH to an 8080 file with a starting load address of 0100H and an execution address of 011AH



# CHAPTER 5 SERIAL LOADER

## 5-1. Introduction

When an SDK-86 is interfaced to an Intel Intellec microcomputer development system, the serial loader program that is supplied with the SDK-C86 kit adds two commands to the serial monitor's command set. These commands allow a user to load an ISIS-II file into SDK memory and to transfer the contents of SDK memory to an ISIS-II file.

With the exception of the R and W commands, all of the serial monitor's commands described in Chapter 4 are available with the serial loader program. Except for the operation of the serial loader's load and transfer commands, serial monitor operation with the development system is identical to its operation with a teletypewriter or CRT terminal; characters entered at the system console are input to the SDK and characters output from the SDK are displayed on the system console. The serial loader has the capability of detecting when the serial monitor is prompting for command entry in order to "intercept" a load or transfer command entered from the system console.

When the serial loader intercepts a load command, it opens the specified file for reading and then issues an R (read hex file) command to the serial monitor followed by the data read from the file. When the serial loader intercepts a transfer command, it opens the specified file for writing and issues a W (write hex file) command and the associated command arguments to the serial monitor. The serial monitor responds by outputting the requested data to the serial port, and the serial loader writes the data into the opened file.

# 5-2. System Operation

Unlike the two monitor programs that reside in ROM, the serial loader program resides on a diskette. Two diskettes are supplied with the SDK-C86 kit. (The contents of both diskettes are identical.) The diskette labeled S.D.D.A. ISIS-II SDK-86 LOADER (part number 9500044) is for single-density drives, and the diskette labeled D.D.D.A. ISIS-II SDK-86 LOADER (part number 9700040) is for double-density drives. Insert the appropriate diskette into the secondary drive and, using the ISIS-II load-and-go command, enter:

#### :Fn:SDK86

where n is the drive unit number of the secondary drive. The serial loader will signon with the message:

#### ISIS-II SDK-86 LOADER, Vx.x

After the serial loader has been loaded (after the sign-on message is displayed) either press the SDK's **SYSTM RESET** key if the serial monitor is located at FF000H or, if the serial monitor is located at FE000H, execute a Go command from the keypad monitor to transfer control to the serial monitor. The serial monitor's sign-on message (SDK-86 MONITOR, Vx.x) will be displayed on the system console followed by the command prompt character (".") to indicate that the system is ready to accept command entry.

# 5-3. Loader Commands

As previously mentioned, the serial loader adds two commands to the serial monitor. These commands (Load Hex File and Transfer Hex File) follow the same syntax conventions described in Chapter 4. Additionally, an Exit command is included with the serial loader to return control to ISIS. Table 5-1 defines the serial loader commands and syntax.

Table 5-1. Serial Loader Command Summary

| Command               | Function/Syntax                                                                                                                                         |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| T (Transfer Hex File) | Tranfers memory block from SDK to ISIS-II file  T[X] <start addr="">,<end addr="">,<filename>[,<exec addr="">]<cr></cr></exec></filename></end></start> |
| L (Load Hex File)     | Loads ISIS-II file into SDK memory<br>L <filename>[,<bias-number>]<cr></cr></bias-number></filename>                                                    |
| E (Exit)              | Returns control to ISIS<br>E <cr></cr>                                                                                                                  |

#### 5-4. Transfer Hex File Command

#### **FUNCTION**

The Transfer Hex File (T) command is used to transfer the contents of a block of SDK memory to an ISIS-II hexadecimal object file in the microcomputer development system.

#### **SYNTAX**

T[X]<start addr>,<end addr>,<filename>[,< exec addr>]<cr>

#### **OPERATION**

To use the Transfer Hex File command, enter T for 8086 file format or TX for 8080 file format and start address and end address of the memory block to be transferred and the filename of the ISIS-II file to receive the memory data. Note that no segment address value is permitted with end address (the start address segment value is implied) and that if no segment address value is specified with start address, the current CS register value is used. When the carriage return is entered, the data contents of the memory block bounded by start address and end address (inclusive) are transferred to the file specified.

Optionally, an execution address can be specified prior to entering the carriage return. This is the memory address that is loaded into the CS and IP registers (IP register only with 8080 format) when the file is loaded with the L command. Depending on the format selected, when an execution address is specified, either an execution start address record containing execution address is entered in the file (8086 format) or the offset address value of execution address is entered in the EOF record (8080 format).

When using the 8086 format (T command), the *start address* segment value (CS register value if a segment value is not specified) is entered in the file's extended address record, and the *start address* offset value is entered in the load address field of the first data record. The segment and offset address values of *execution address* are entered in the execution start address record (CS register contents if a segment address value is not specified with *execution address*).

When using the 8080 format (TX command), the start address offset value is entered in the load address field of the first data record. The execution address, if specified, is entered in the EOF record. Note that a segment address value is not permitted with execution address or end address and that the start address segment value is used only to define the starting address of the memory block and that it is not entered in the file.

#### **ERROR CONDITIONS**

End address specified is less than the offset value of start address

ISIS-II type errors (1-99)

Timeout

Checksum error

# **EXAMPLES**

Example 1: Transfer, in the 8086 file format, the SDK memory contents between locations 0200H and 0600H, relative to the current

CS register, into the ISIS-II file named :F2:GARYL

\_\_T 200,600,:F2:GARYL<cr>

.

## 5-5. Load Hex File Command

#### **FUNCTION**

The Load Hex File command loads an ISIS-II hexadecimal object file from the microcomputer development system into SDK memory.

#### **SYNTAX**

L<filename>[,<bias number>]<cr>

#### **OPERATION**

To use the Load Hex File command enter L and the ISIS-II filename of the file to be loaded. The data read from the specified file will be written into memory beginning at each record's load address. If the file is in the 8086 format and includes an execution start address record, the CS and IP registers will be updated with the execution address specified in that record. If the file is in the 8080 format and includes an EOF (end-of-file) record, the IP register is updated with the execution address specified in the EOF record. Note that a segment address value is not used with the 8080 file format; the data read is written into memory locations relative to a segment value of zero and, when an EOF record execution address is specified, the CS register is not changed.

When an optional bias number is specified, it is added to each record's load address to offset the file in memory.

#### **ERROR CONDITIONS**

Attempting to load data into non-existent or read-only memory

ISIS-II type errors (1-99)

Timeout

Checksum error

#### **EXAMPLES**

Example 1: Load the ISIS-II file named F1:GEL.HEX into SDK memory, 0100H locations above the load addresses in the file.

\_L F1:GEL.HEX, 100<cr>

#### 5-6. Exit Command

#### **FUNCTION**

The exit command transfers control from the monitor to ISIS.

**SYNTAX** 

E<cr>

# 5-7. System I/O Routines

The SDK-86 loader diskette also includes two libraries containing I/O routines for the console and teletypewriter paper tape reader and punch. Although the routines in both libraries have the same names and functions, two libraries are necessary to support the two types of subroutine linkages provided by the 8086 architecture. The routines in SDKIOS.LIB are called with intrasegment subroutine calls (a PL/M-86 module compiled with the "small" control generates this type of call). The routines in SDKIOL.LIB are called with intersegment subroutine calls (a PL/M-86 module compiled with either the "medium" or "large" control generates this type of call). The routines in both libraries are written in PL/M-86. The modules in SDKIOS.LIB are compiled with the "small" control, and the modules in SDKIOL.LIB are compiled with the "large" control. The names assigned to the segments, classes and groups are the standard names generated by the PL/M-86 compiler. (See MCS-86 Software Development Utilities Operating Instructions for ISIS-II Users, Order Number 9800639.)

When using the serial loader program, the console input and output routines provided in the library should be used for console I/O. (The loader has special requirements which are met by the library routines.) The paper tape routines (RI and PO) only perform I/O when a teletypewriter is connected directly to the SDK-86's serial interface port.

# 5-8. Console Input Routine

The console input routine (CI) returns an 8-bit character received from the system console to the caller in the AL register. The AX, CX and DX registers and CPU condition codes are affected by this operation.

When a Control-S (13H) or Control-Q (11H) character is read, it is discarded and another character is read. This function is necessary to support the control character feature of the CO routine.

Serial Loader **SDK-86** 

#### **EXAMPLES**

Example 1: PL/M-86 CI Call

CI: PROCEDURE BYTE EXTERNAL;

END CI;

DECLARE CHAR BYTE;

CHAR = CI AND 7FH;

/\* INPUT CHARACTER AND STRIP PARITY BIT \*/

#### Example 2: ASM86 CI Intrasegment Call

ASSUME DS:DATA,SS:STACK,CS:CODE

DATA

SEGMENT PUBLIC 'DATA'

CHAR

DB ?

DATA ENDS

STACK

SEGMENT STACK 'STACK'

DW

15 DUP? WORD

BASESTACK LABEL

STACK **ENDS** 

CODE

SEGMENT PUBLIC 'CODE'

EXTRN CI:NEAR

INIT:

MOV AX,STACK

MOV SS,AX ; SS

MOV SP,OFFSET BASESTACK ; INITIALIZE SP

MOV AX,DATA ; INITIALIZE

; INITIALIZE

MOV

DS,AX

CI

; DS

CALL

; INPUT CHARACTER FROM CONSOLE

AND MOV

AL,7FH CHAR,AL ; STRIP OFF PARITY BIT ; SAVE CHARACTER

CODE

**ENDS** 

END

INIT

```
Example 3: ASM86 CI Intersegment Call
           EXTRN
                     CI:FAR
            ASSUME
                     DS:MYDATA,SS:STACK,CS:MYCODE
MYDATA
           SEGMENT 'DATA'
CHAR
           DB
                     ?
MYDATA
           ENDS
STACK
           SEGMENT STACK 'STACK'
            DW
                     16 DUP?
BASESTACK
           LABEL
                     WORD
STACK
           ENDS
MYCODE
           SEGMENT 'CODE'
INIT:
           MOV
                     AX,STACK
                                          ; INITIALIZE
           MOV
                     SS,AX
                                          ; SS
           MOV
                     SP, OFFSET BASESTACK; INITIALIZE SP
           MOV
                     AX,MYDATA
                                          ; INITIALIZE
           MOV
                     DS,AX
                                          ; DS
           CALL
                     CI
                                          : INPUT CHARACTER FROM CONSOLE
           AND
                     AL.7FH
                                          ; STRIP OFF PARITY BIT
           MOV
                     CHAR,AL
                                          : SAVE CHARACTER
MYCODE
           ENDS
           END
                     INIT
```

# 5-9. Console Output Routine

The console output routine (CO) transmits an 8-bit character, passed from the caller on the stack in the low-order byte, to the system console. The AX, CX and DX registers and the CPU conditions codes are affected by this operation.

Before the character is output, the console output routine checks to see if a Control-S has been input. If a Control-S has been input, the monitor waits until a Control-Q is input before outputting the character. Consequently, if a Control-S is entered at the console when console output is pending, the output is stopped temporarily. Entering Control-Q resumes output.

#### **EXAMPLES**

```
Example 1: PL/M-86 CO Call
 CO:PROCEDURE(X) EXTERNAL:
    DECLARE X BYTE:
    END CO:
 DECLARE CHAR BYTE;
                  /* OUTPUT CHARACTER */
 CALL CO(CHAR);
```

```
Example 2: ASM86 CO Intrasegment Call
           ASSUME DS:DATA,SS:STACK,CS:CODE
           SEGMENT PUBLIC 'DATA'
DATA
CHAR
           DB
           ENDS
DATA
STACK
           SEGMENT STACK 'STACK'
                     15 DUP?
           DW
                     WORD
BASESTACK LABEL
           ENDS
STACK
CODE
           SEGMENT PUBLIC 'CODE'
           EXTRN
                     CO:NEAR
INIT:
           MOV
                     AX,STACK
                                         ; INITIALIZE
           MOV
                     SS,AX
                                         ; SS
           MOV
                     SP,OFFSET BASESTACK; INITIALIZE SP
                                         ; INITIALIZE
           MOV
                     AX,DATA
                                         ; DS
           MOV
                     DS,AX
                                         ; LOAD CHARACTER INTO AL
           MOV
                     AL,CHAR
           PUSH
                     AX
                                         ; PUSH CHARACTER ONTO STACK
                     CO
                                         ; OUTPUT CHARACTER TO CONSOLE
           CALL
CODE
           ENDS
           END
                     INIT
Example 3: ASM86 CO Intersegment Call
           EXTRN
                     CO:FAR
           ASSUME DS:MYDATA,SS:STACK,CS:MYCODE
           SEGMENT 'DATA'
MYDATA
CHAR
           DB
           ENDS
MYDATA
           SEGMENT STACK 'STACK'
STACK
           DW
                     16 DUP?
BASESTACK LABEL
                     WORD
STACK
           ENDS
MYCODE
           SEGMENT 'CODE'
INIT:
           MOV
                     AX,STACK
                                         ; INITIALIZE
           MOV
                     SS,AX
                                         ; SS
           MOV
                     SP, OFFSET BASESTACK; INITIALIZE SP
           MOV
                     AX, MYDATA
                                         ; INITIALIZE
           MOV
                     DS,AX
                                         ; DS
           MOV
                     AL, CHAR
                                         ; LOAD CHARACTER INTO AL
           PUSH
                     AX
                                         ; PUSH CHARACTER ONTO STACK
           CALL
                     CO
                                         ; OUTPUT CHARACTER TO CONSOLE
MYCODE
           ENDS
```

END

INIT

# 5-10. Reader Input Routine

The reader input routine, (RI) returns an 8-bit character received from the paper tape reader to the caller in the AL register. The AX, CX and DX registers and the CPU condition codes are affected by this operation. If a character is not received within two seconds, the carry flag of the FL register is set on return.

#### **EXAMPLES**

```
Example 1: PL/M-86 RI Call
```

```
RI: PROCEDURE BYTE EXTERNAL; END RI;
```

```
DECLARE CHAR BYTE;
```

```
CHAR = RI; /* READ CHARACTER */
IF CARRY THEN GOTO END$OF$FILE;
CHAR = CHAR AND 7FH; /* STRIP PARITY BIT */
```

#### Example 2: ASM86 RI Intrasegment Call

```
ASSUME DS:DATA,SS:STACK,CS:CODE
            SEGMENT PUBLIC 'DATA'
DATA
CHAR
            DB
DATA
            ENDS
STACK
            SEGMENT STACK 'STACK'
            DW
                      15 DUP?
BASESTACK LABEL
                      WORD
STACK
            ENDS
            SEGMENT PUBLIC 'CODE'
CODE
            EXTRN
                      RI:NEAR
INIT:
                                           ; INITIALIZE
            MOV
                      AX,STACK
            MOV
                      SS.AX
                                           : SS
                      SP, OFFSET BASESTACK; INITIALIZE SP
            MOV
            MOV
                      AX,DATA
                                           ; INITIALIZE
            MOV
                      DS,AX
                                           ; DS
            CALL
                                           ; INPUT CHARACTER FROM READER
                                           ; EXIT IF NO MORE
            JB
                      DONE
                                           STRIP OFF PARITY BIT
            AND
                      AL,7FH
            MOV
                      CHAR, AL
                                           ; SAVE CHARACTER
            ENDS
CODE
            END
                      INIT
```

# Example 3: ASM86 RI Intersegment Call

**EXTRN** RI:FAR

ASSUME DS:MYDATA,SS:STACK,CS:MYCODE

**MYDATA** CHAR

SEGMENT 'DATA' DB

**MYDATA** 

**ENDS** 

STACK

SEGMENT STACK 'STACK'

DW

16 DUP? WORD

**BASESTACK** 

LABEL

STACK

**ENDS** 

MYCODE

SEGMENT 'CODE'

INIT:

MOV MOV AX,STACK SS,AX

; INITIALIZE SS

MOV MOV

SP, OFFSET BASESTACK; INITIALIZE SP AX, MYDATA

; INITIALIZE

MOV DS,AX ; DS

CALL RI DONE JB AND AL,7FH CHAR,AL MOV

; INPUT CHARACTER FROM READER

; EXIT IF NO MORE STRIP OFF PARITY BIT ; SAVE CHARACTER

MYCODE

**ENDS END** 

# 5-11. Punch Output Routine

INIT

The punch output routine (PO) outputs an 8-bit character, passed from the caller on the stack in the low-order byte, to the paper tape punch. The AX and DX registers and the CPU condition codes are affected by this operation.

## **EXAMPLES**

Example 1: PL/M-86 PO Call

PO: PROCEDURE(X) EXTERNAL;

DECLARE X BYTE;

END PO;

DECLARE CHAR BYTE;

CALL PO(CHAR);

/\* PUNCH CHARACTER \*/

#### Example 2: ASM86 PO Intrasegment Call

ASSUME DS:DATA,SS:STACK,CS:CODE

DATA

SEGMENT PUBLIC 'DATA'

CHAR

DB

DATA

**ENDS** 

| STACK<br>BASESTACK<br>STACK | DW                       | STACK 'STACK'<br>15 DUP ?<br>WORD                            |                                                                                        |
|-----------------------------|--------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------------|
| CODE                        |                          | PUBLIC 'CODE'<br>PO:NEAR                                     |                                                                                        |
| INIT:                       | MOV<br>MOV<br>MOV<br>MOV | AX,STACK<br>SS,AX<br>SP,OFFSET BASESTACK<br>AX,DATA<br>DS,AX | ; INITIALIZE ; SS ; INITIALIZE SP ; INITIALIZE ; DS                                    |
|                             | MOV<br>PUSH<br>CALL      | AL,CHAR<br>AX<br>PO                                          | ; LOAD CHARACTER INTO AL<br>; PUSH CHARACTER ONTO STACK<br>; OUTPUT CHARACTER TO PUNCH |
|                             | ner saton                |                                                              |                                                                                        |
| CODE                        | ENDS<br>END              | INIT                                                         |                                                                                        |
| Example 3:                  | ASM86 PC                 | O Intersegment Call                                          |                                                                                        |
|                             | EXTRN                    | PO:FAR                                                       |                                                                                        |
|                             | ASSUME                   | DS:MYDATA,SS:STACK,C                                         | CS:MYCODE                                                                              |
| MYDATA<br>CHAR<br>MYDATA    | SEGMENT<br>DB<br>ENDS    | 'DATA'                                                       |                                                                                        |
| STACK                       | SEGMENT<br>DW            | STACK 'STACK' 16 DUP?                                        |                                                                                        |
| BASESTACK<br>STACK          | LABEL<br>ENDS            | WORD                                                         |                                                                                        |
| MYCODE                      | SEGMENT                  | 'CODE'                                                       |                                                                                        |
| INIT:                       | MOV<br>MOV               | AX,STACK<br>SS,AX                                            | ; INITIALIZE<br>: SS                                                                   |
|                             | MOV<br>MOV<br>MOV        | SP,OFFSET BASESTACK<br>AX,MYDATA<br>DS,AX                    |                                                                                        |
|                             | MOV<br>MOV               | SP,OFFSET BASESTACK<br>AX,MYDATA<br>DS,AX                    | ; INITIALIZE SP<br>; INITIALIZE<br>; DS                                                |



# CHAPTER 6 PERIPHERAL INTERFACING

### 6-1. Introduction

This chapter provides the necessary information for connecting a teletypewriter/CRT terminal or an Intel Intellec microcomputer development system to the SDK-86's serial interface port. Additionally, the connector pin assignments for the two parallel I/O ports (P1 and P2) and the bus expansion interface are provided.

### 6-2. Serial Interface Port

The serial interface port uses a DB-25S female type 25 pin EIA connector (J7). The required mating connector (not supplied) is a DB-25P. The pin assignments for the connector are determined by installing shorting plugs at 2- by 18-pin header W1-W18 (located just below serial interface connector J7). The two rows of header pins are grouped into four sets as noted by the silkscreening on the board (TTY, CRT, MDS-TTY and MDS-CRT). Depending on the device to be interfaced, shorting plugs are inserted over all of the pins in the appropriate set. Table 6-1 defines the connector pin assignments and signal names for each set. Note that to use the serial interface, the SDK-86 requires a -12 volt supply.

Table 6-1. Serial Interface Connector J7 Pin Assignments

| PIN | HEADER W1-W18 SHORTING PLUG CONFIGURATION |               |               |                |
|-----|-------------------------------------------|---------------|---------------|----------------|
| PIN | TTY                                       | CRT           | MDS-TTY       | MDS-CRT        |
| 1   |                                           |               |               |                |
| 2   |                                           | RECEIVE DATA  |               | TRANSMIT DATA  |
| 3   |                                           | TRANSMIT DATA |               | RECEIVE DATA   |
| 4   |                                           |               |               | THE OEIVE DATA |
| 5   |                                           |               |               |                |
| 6   |                                           |               |               |                |
| 7   | GROUND                                    | GROUND        | GROUND        | GROUND         |
| 8   |                                           |               |               |                |
| 9   |                                           |               |               |                |
| 10  |                                           |               |               |                |
| 11  |                                           |               |               |                |
| 12  | RECEIVE DATA                              |               | TRANSMIT DATA |                |
| 13  | TRANSMIT DATA                             |               | RECEIVE DATA  | ,              |
| 14  |                                           |               |               |                |
| 15  |                                           |               |               |                |
| 16  | READER CONTROL                            | . ,           |               |                |
| 17  | -                                         |               |               |                |
| 18  |                                           |               |               |                |
| 19  |                                           |               |               |                |
| 20  |                                           |               |               |                |
| 21  | READER CONTROL RETURN                     |               |               |                |
| 22  |                                           |               |               |                |
| 23  | DE0511/5 DATA D5511D11                    |               |               |                |
| 24  | RECEIVE DATA RETURN                       |               |               |                |
| 25  | TRANSMIT DATA RETURN                      |               |               |                |

The SDK-86's baud rate must be set to match the baud rate of the device connected to the serial interface port. The SDK-86's baud rate is determined by installing a shorting plug at BAUD RATE SELECT header W19-W26 (located towards the center of the Serial Interface area). The available baud rates are individually silkscreened adjacent to their associated header pins. To select the baud rate, simply install a shorting plug over the corresponding pair of header pins. Note that for 110 baud, two shorting plugs are installed.

### 6-3. SDK-C86 Interface

The SDK-C86 System Design Kit includes a cable for connecting the SDK-86 to any of the Intel Intellec microcomputer development systems. This cable (Intel part number 4001927) is installed between serial interface connector J7 on the SDK-86 and the appropriate connector on the rear of the development system enclosure. Figure 6-1 shows the interface configurations for the various systems and console devices. Referring to the figure, the shorting plug set to be installed on header W1-W18 is shown within the SDK-86 outline as is the required baud rate.



Figure 6-1. Intellec® Microcomputer Development System Interfacing

### 6-4. Parallel I/O Ports

The input/output signals for the two 8255A parallel I/O port circuits are available at the two sets of double row pads to the left of the circuits. As indicated by the silkscreen, the set of pads at J5 corresponds to port circuit P2, and the set of pads at J6 corresponds to port circuit P1. The individual 8-bit ports (A, B and C) also are silkscreened. The pin assignments for the individual port bits are defined in Tables 6-2 (Port 2-J5) and 6-3 (Port 1-J6).

If an off-board peripheral device is to be interfaced to the parallel I/O ports, the 2by 25-pin headers supplied with the kit can be installed to permit ribbon cable and mass-termination type connectors to be used. Conversely, if the parallel I/O ports are to be interfaced to circuitry installed in the user design area, wire-wrap pins (not supplied) can be installed in the individual pads (from the bottom of the board) to allow wire-wrap connections into the user design area.

Table 6-2. Parallel I/O Port Connector J5 Pin Assignments

Pin **Function** Pin **Function** Ground Port P2A bit 0 34

3 38 Port P2A bit 1 Port P2A bit 2 5 42 Port P2A bit 3 46 9 48 Port P2A bit 4 44 Port P2A bit 5 11 Port P2A bit 6 13 40 Port P2A bit 7 15 Ground 36 17 Ground 24 Port P2C bit 0 2 Port P2C bit 1 19 21 4 Port P2C bit 2 23 6 Port P2C bit 3 Port P2C bit 4 25 26 28 Port P2C bit 5 27 Port P2C bit 6 30 29 31 Ground 32 Port P2C bit 7 Port P2B bit 0 33 Ground 10 Port P2B bit 1 35 22 Port P2B bit 2 37 18 39 14 Port P2B bit 3 41 16 Port P2B bit 4 43 20 Port P2B bit 5 Port P2B bit 6 45 12 47 Ground 8 Port P2B bit 7 49 50 Not Used Ground

Table 6-3. Parallel I/O Port Connector J6 Pin Assignments

| Pin                               | Function | Pin                                          | Function                                                                                                                |
|-----------------------------------|----------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| 1<br>3<br>5<br>7<br>9<br>11<br>13 | Ground   | 36<br>40<br>44<br>48<br>50<br>46<br>42<br>38 | Port P1A bit 0 Port P1A bit 1 Port P1A bit 2 Port P1A bit 3 Port P1A bit 4 Port P1A bit 5 Port P1A bit 6 Port P1A bit 7 |
| 17<br>19<br>21                    | Ground   | 26<br>24<br>22                               | Port P1C bit 0<br>Port P1C bit 1<br>Port P1C bit 2                                                                      |

Table 6-3. Parallel I/O Port Connector J6 Pin Assignments

| Pin | Function | Pin | Function       |
|-----|----------|-----|----------------|
| 23  | <b>A</b> | 20  | Port P1C bit 3 |
| 25  |          | 28  | Port P1C bit 4 |
| 27  |          | 30  | Port P1C bit 5 |
| 29  |          | 32  | Port P1C bit 6 |
| 31  | Ground   | 34  | Port P1C bit 7 |
| 33  | Ground   | 16  | Port P1B bit 0 |
| 35  | <b>A</b> | 12  | Port P1B bit 1 |
| 37  |          | 8   | Port P1B bit 2 |
| 39  |          | 4   | Port P1B bit 3 |
| 41  |          | 6   | Port P1B bit 4 |
| 43  |          | 10  | Port P1B bit 5 |
| 45  |          | 14  | Port P1B bit 6 |
| 47  | Ground   | 18  | Port P1B bit 7 |
| 49  | Ground   | 2   | Not Used       |

## 6-5. Bus Expansion Interface

The bus expansion logic, which allows the CPU bus to be extended into the user design area as well as off the board, uses the two sets of double row pads adjacent to the user design area for interfacing. The set of pads designated J1 and J2 provides access to the CPU's data bus and certain control signals while the set of pads designated J3 and J4 provides access to the CPU's 20-bit address bus and the remaining control signals. The signals appearing at J3 and J4 are pin-for-pin identical, while five additional signals are available at J2 that are not available at J1 (the remaining signals are pin-for-pin identical). Table 6-4 lists the pin assignments and corresponding silkscreen signal nomenclature. Note that the signal names in parentheses are the actual signal names appearing on the schematics.

Table 6-4. Bus Expansion Pin Assignments

| Pin* | Connector J1/J2<br>Signal Name | Connector J3/J4<br>Signal Name |
|------|--------------------------------|--------------------------------|
| 2    | D0 (BD0)                       | BHE                            |
| 4    | D1 (BD1)                       | A0                             |
| 6    | D2 (BD2)                       | A1                             |
| 8    | D3 (BD3)                       | A2                             |
| 10   | D4 (BD4)                       | A3                             |
| 12   | D5 (BD5)                       | A4                             |
| 14   | D6 (BD6)                       | A5                             |
| 16   | D7 (BD7)                       | A6                             |
| 18   | D8 (BD8)                       | A7                             |
| 20   | D9 (BD9)                       | A8                             |
| 22   | D10 (BD10)                     | A9                             |
| 24   | D11 (BD11)                     | A10                            |
| 26   | D12 (BD12)                     | A11                            |
| 28   | D13 (BD13)                     | A12                            |
| 30   | D14 (BD14)                     | A13                            |
| 32   | D15 (BD15)                     | A14                            |
| 34   | RST (RESET OUT)                | A15                            |
| 36   | PCLK                           | A16                            |
| 38   | INTR                           | A17                            |
| 40   | TEST                           | A18                            |
| 42   | HOLD                           | A19                            |

<sup>\*</sup>All undesignated pins are logic ground.

Table 6-4. Bus Expansion Pin Assignments (Cont'd.)

| Pin*                                                              | Connector J1/J2<br>Signal Name                                                          | Connector J3/J4<br>Signal Name                 |
|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------|
| 44<br>46<br>48<br>50<br>J2-41<br>J2-43<br>J2-45<br>J2-47<br>J2-49 | HLDA (BHLDA)  DEN (BDEN/)  DT/R (BDT/R)  ALE (BALE)  CSX CSY S3 (BS3) S4 (BS4) S5 (BS5) | M/IO (BM/IO) RD (BRD/) WR (BWR/) INTA (BINTA/) |

<sup>\*</sup>All undesignated pins are logic ground.

Since the two sets of signals at J1/J2 and J3/J4 are identical (except for the additional signals at J2), the CPU bus can be routed off-board by installing one of the supplied 2- by 25-pin headers into one of the double row pads in each set (e.g., J2 and J4) and also can be wired into the user design area through the other set (e.g., J1 and J3).

Note that the INTR, TEST and HOLD signals were disabled when the kit was assembled (shorting plugs were installed in W36, W37 and W38) and that if the circuit to be interfaced to the CPU bus requires any of these signals, the corresponding shorting plugs must be removed.

growthethi lavenque

3.8.0475

pt. Washington of the same to the same to

CONTROL OF THE CONTRO

Public and company states on the supplier of the company of the co



# APPENDIX A TELETYPEWRITER MODIFICATIONS

### A-1. Introduction

This appendix provides information required to modify a Model ASR-33 Teletypewriter for use with the SDK-86.

### A-2. Internal Modifications

#### WARNING

Hazardous voltages are exposed when the top cover of the teletypewriter is removed. To prevent accidental shock, disconnect the teleprinter power cord before proceeding beyond this point.

Remove the top cover and modify the teletypewriter as follows:

- a. Remove blue lead from 750-ohm tap on current source register; reconnect this lead to 1450-ohm tap. (Refer to figures A-1 and A-2.)
- b. On terminal block, change two wires as follows to create an internal full-duplex loop (refer to figures A-1 and A-3):
  - Remove brown/yellow lead from terminal 3; reconnect this lead to terminal
     5.
  - 2. Remove white/blue lead from terminal 4; reconnect this lead to terminal 5.
- c. On terminal block, remove violet lead from terminal 8; reconnect this lead to terminal 9. This changes the receiver current level from 60 mA to 20 mA.

A relay circuit card must be fabricated and connected to the paper tape reader driver circuit. The relay circuit card to be fabricated requires a relay, a diode, a thyractor, a small 'vector' board for mounting the components, and suitable hardware for mounting the assembled relay card.

A circuit diagram of the relay circuit card is included in figure A-4; this diagram also includes the part numbers of the relay, diode, and thyractor. (Note that a 470-ohm resistor and a  $0.1~\mu F$  capacitor may be substituted for the thyractor.) After the relay circuit card has been assembled, mount it in position as shown in figure A-5. Secure the card to the base plate using two self-tapping screws. Connect the relay circuit to the distributor trip magnet and mode switch as follows:

- a. Refer to figure A-4 and connect a wire (Wire 'A') from relay circuit card to terminal L2 on mode switch. (See figure A-6.)
- b. Disconnect brown wire shown in figure A-7 from plastic connector. Connect this brown wire to terminal 12 on mode switch. (Brown wire will have to be extended.)
- c. Refer to figure A-4 and connect a wire (Wire 'B') from relay circuit board to terminal L1 on mode switch.

### A-3. External Connections

Connect a two-wire receive loop, a two-wire send loop, and a two-wire tape reader control loop to the external device as shown in figure A-4. The external connector pin numbers shown in figure A-4 are for interface with an RS232C type, 25-pin connector.



Figure A-1. Teletype Component Layout



Figure A-2. Current Source Resistor



Figure A-3. Terminal Block



Figure A-4. Teletypewriter Modifications



Figure A-5. Relay Circuit



Figure A-6. Mode Switch



Figure A-7. Distributor Trip Magnet



# APPENDIX B INTEL® ROM/EPROM MEMORY EXPANSION

### **B-1.** Introduction

This appendix examines the interfacing of additional read-only memory to either the user design area or off-board. The memory devices cited in this appendix are members of the Intel 5 volt ROM and EPROM family and are interfaced to the SDK-86 through the bus expansion logic. For additional information on this ROM/EPROM family, refer to *Application of Intel's 5V EPROM and ROM Family for Microprocessor Systems*, Application Note AP-30.

### **B-2. ROM/EPROM Family Characteristics**

The current and future generations of Intel 5 volt ROMs and EPROMs operate from a single 5 volt source and feature 2-line control (separate Chip Enable and Output Enable inputs) to eliminate bus contention problems in multiple memory systems. While a majority of the currently available devices are contained in 24-pin packages, the 2364 ROM and next generation devices, because of their increased density, require a 28-pin package. Even though the number of pins on the package is increased, compatibility within the entire family is maintained by keeping the functions on the lower 24 pins consistent between the two package sizes as shown in Figure B-1.



Figure B-1. 5 Volt ROM/EPROM Compatible Family

The following table defines the Intel 5 volt ROM/EPROM family.

Device Memory Organization Memory **Package** Device Type Capacity Size 2758 **EPROM** 8K 1K × 8 24-pin 2316E **ROM** 16K 2K × 8 24-pin 2616 **PROM** 16K 2K × 8 24-pin 2716 **EPROM** 16K 2K × 8 24-pin 2332 **ROM** 32K 4K × 8 24-pin 2732 **EPROM** 32K 4K × 8 24-pin 2364 **ROM** 8K × 8 64K 28-pin

Table B-1. Intel® 5V ROM/EPROM Family

### B-3. 24-Pin and 28-Pin Sites

As mentioned in the previous section, Intel ROMs and EPROMs, depending on the bit density, are available in either a 24- or 28-pin package. To ensure future upgrading, all designs currently using 24-pin devices should be planned for 28-pin sites. In this way, when a higher-density device of 28 pins is used, the required circuit modifications are limited to only the proper connection of the next high-order address bit(s).

### B-4. 8086 Compatability

Since the 8086 CPU is capable of 16-bit word memory access, ROM and EPROM devices are used in pairs. One device is connected to the low-order data byte (D0-D7), and the other device is connected to the high-order data byte (D8-D15). By offsetting the address bit inputs to the two devices (e.g., A1 address bit connected to the A0 address input of each device) and by using the A0 address bit as a decode input in conjunction with the  $\overline{BHE}$  (Byte High Enable) signal, either the low- or high-order byte or both bytes can be accessed. Table B-2 defines the  $A0/\overline{BHE}$  truth table used by the SDK-86 for byte and word memory access.

**Decode Input Byte Accessed** BHE A0 0 Both Bytes (D0-D15) 0 High Byte (D8-D15) 1 0 Low Byte (D0-D7) 0 1 1 1 None

Table B-2. Byte Decoding

## B-5. Design Example 1

The following design example (Figure B-2) shows the logic design for the addition of 16, 32 or 64K ROM/EPROM devices in the unassigned SDK-86 memory area immediately below FC000H. In the example, 28-pin sites are used to allow compatibility with a 64K device (2364).



Figure B-2. Design Example 1

In the example, the ALE (Address Latch Enable) signal is gated with the enabled address output from the 7430 for compatibility with edge-enabled devices and is not required for the currently available devices in the family. Table B-3 defines the jumper configurations for 16, 32 and 64K devices. Refer to Table 6-4 for expansion bus interface pin assignments.

| Device     | Jumpers<br>Installed | Memory Block Selected |
|------------|----------------------|-----------------------|
| 2316E/2716 | W1, W3, W4           | FB000H-FBFFFH         |
| 2332/2732  | W2, W4               | FA000H-FBFFFH         |
| 2364       | W2                   | F8000H-FBFFFH         |

Table B-3. Jumper Configurations

## B-6. Design Example 2

The following design example (Figure B-3) shows a logic design which uses the two bus expansion address block decode signals (CSX and CSY) generated by the SDK-86. Since the combined address capability of these two signals is 8K bytes (addresses FC000H-FDFFFH), the maximum memory device that can be used is a 2332/2732, 4K × 8 ROM/EPROM, and 28-pin sites consequently are not required.



Figure B-3. Design Example 2

Since the existing 16K and 32K devices are static, the ALE signal used in design example 1 is not used. The following table defines the jumper configurations for a 16K or 32K device and the corresponding memory block accessed.

Table B-4. Jumper Configurations

| Device     | Jumpers<br>Installed | Memory Block Selected |
|------------|----------------------|-----------------------|
| 2316E/2716 | W1, W4               | FD000H-FDFFFH         |
|            | W1, W3               | FC000H-FCFFFH         |
| 2332/2732  | W2, W5               | FC000H-FDFFFH         |





### REQUEST FOR READER'S COMMENTS

Intel's Technical Publications Departments attempt to provide publications that meet the needs of all Intel product users. This form lets you participate directly in the publication process. Your comments will help us correct and improve our publications. Please take a few minutes to respond.

Please restrict your comments to the usability, accuracy, readability, organization, and completeness of this publication. If you have any comments on the product that this publication describes, please contact your Intel representative. If you wish to order publications, contact the Intel Literature Department (see page ii of this manual).

| 1.    | Please describe any errors you found in this publication (include page number).                                              |
|-------|------------------------------------------------------------------------------------------------------------------------------|
|       |                                                                                                                              |
| 2.    | Does the publication cover the information you expected or required? Please make suggestions for improvement.                |
|       |                                                                                                                              |
| 3.    | Is this the right type of publication for your needs? Is it at the right level? What other types of publications are needed? |
|       |                                                                                                                              |
| 4.    | Did you have any difficulty understanding descriptions or wording? Where?                                                    |
| 5.    | Please rate this publication on a scale of 1 to 5 (5 being the best rating).                                                 |
| NΑ    | ME DATE                                                                                                                      |
| ГІТ   | LE                                                                                                                           |
| CO    | MPANY NAME/DEPARTMENT                                                                                                        |
| ٩D    | DRESS                                                                                                                        |
| CIT   | Y STATE ZIP CODE<br>(COUNTRY)                                                                                                |
| م ا ۲ | ase check here if you require a written reply                                                                                |

### WE'D LIKE YOUR COMMENTS . . .

This document is one of a series describing Intel products. Your comments on the back of this form will help us produce better manuals. Each reply will be reviewed. All comments and suggestions become the property of Intel Corporation.

If you are in the United States, use the preprinted address provided on this form to return your comments. No postage is required. If you are not in the United States, return your comments to the Intel sales office in your country. For your convenience, a list of international sales offices is provided on the back cover of this document.



NO POSTAGE
NECESSARY
IF MAILED
IN THE
UNITED STATES

## **BUSINESS REPLY MAIL**

FIRST CLASS

PERMIT NO. 79

HILLSBORO, OR

POSTAGE WILL BE PAID BY ADDRESSEE

Intel Corporation DTO Technical Publications, HF2-38 5200 N.E. Elam Young Parkway Hillsboro, Oregon 97124-9987





INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, California 95051 (408) 987-8080

Printed in U.S.A.

**DEVELOPMENT SYSTEMS**